Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/larapulse/database
PHP library and ORM to handle DB connection, apply C.R.U.D. operations
https://github.com/larapulse/database
database mysql mysql-database orm orm-library orm-php-framework pdo pdo-mysql pdo-php pdo-wrapper postgres postgresql
Last synced: 3 days ago
JSON representation
PHP library and ORM to handle DB connection, apply C.R.U.D. operations
- Host: GitHub
- URL: https://github.com/larapulse/database
- Owner: larapulse
- License: mit
- Created: 2017-09-30T12:29:46.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-12-12T17:34:58.000Z (about 7 years ago)
- Last Synced: 2024-12-15T07:35:47.521Z (25 days ago)
- Topics: database, mysql, mysql-database, orm, orm-library, orm-php-framework, pdo, pdo-mysql, pdo-php, pdo-wrapper, postgres, postgresql
- Language: PHP
- Size: 32.2 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: docs/CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: docs/CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Database
[![Latest Version on Packagist][ico-version]][link-packagist]
[![Software License][ico-license]](LICENSE.md)
[![Build Status][ico-travis]][link-travis]
[![Coverage Status][ico-scrutinizer]][link-scrutinizer]
[![Quality Score][ico-code-quality]][link-code-quality]PHP library and ORM to handle DB connection, apply C.R.U.D. operations.
## Install
Via Composer
``` bash
$ composer require thephpleague/database
```## Usage
``` php
$config = [
'host' => 'localhost',
'port' => 3306,
'database' => 'master_db',
'username' => 'root',
'password' => '',
];$connection = new League\Database\ConnectionManager('core', $config);
```### `BulkSql` usage
Bulk SQL classes could be useful in scripts, when you need to insert big amount of records.
**Example 1:**
`BulkInsert` usage
``` php
use League\Database\BulkSql\BulkInsert;$db = $connection->getMasterConnection();
$bulkInsert = new BulkInsert($db, 'users');
$bulkInsert
->setItemsPerQuery(50)
->useIgnore()
->disableIndexes();try {
$db->beginTransaction();
foreach ($users as $user) {
$bulkInsert->add($user);
}
$bulkInsert->finish();
$affectedCount = $bulkInsert->getAffectedCount();
$db->commit();
} catch (\PDOException $e) {
$db->rollBack();
}
```**Example 2:**
`BulkReplace` and `BulkDelete` usage (could be useful with feeds)
``` php
use League\Database\BulkSql\BulkReplace;
use League\Database\BulkSql\BulkDelete;$db = $connection->getMasterConnection();
$bulkReplace = new BulkReplace($db, 'offers');
$bulkReplace->setItemsPerQuery(500);
$bulkDelete = new BulkDelete($db, 'offers');
$bulkDelete->setItemsPerQuery(1000);try {
$db->beginTransaction();
foreach ($offers as $offer) {
$flag = $offer['deltaStatus'] ?? null;
switch ($delta) {
case 'REMOVE':
$bulkDelete->add(['id' => $data['id']]);
break;
case 'ADD':
$bulkReplace->add($data);
break;
default:
$logger->notice("Unsupported delta flag \"{$flag}\"";
}
}$bulkReplace->finish();
$bulkDelete->finish();
$db->commit();
$insertsCount = $bulkReplace->getInsertedCount();
$updatesCount = $bulkReplace->getReplacedCount();
$deletesCount = $bulkDelete->getAffectedCount();
} catch (\PDOException $e) {
$db->rollBack();
}
```## Change log
Please see [CHANGELOG](docs/CHANGELOG.md) for more information on what has changed recently.
## Testing
``` bash
$ composer test
```## Contributing
Please see [CONTRIBUTING](docs/CONTRIBUTING.md) and [CODE_OF_CONDUCT](docs/CODE_OF_CONDUCT.md) for details.
## Security
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
## Credits
- [Sergey Podgornyy][link-author]
- [All Contributors][link-contributors]## License
The MIT License (MIT). Please see [License File](LICENSE.md) for more information.
[ico-version]: https://img.shields.io/packagist/v/thephpleague/database.svg?style=flat-square
[ico-license]: https://img.shields.io/badge/license-MIT-brightgreen.svg?style=flat-square
[ico-travis]: https://img.shields.io/travis/larapulse/database/master.svg?style=flat-square
[ico-scrutinizer]: https://img.shields.io/scrutinizer/coverage/g/larapulse/database.svg?style=flat-square
[ico-code-quality]: https://img.shields.io/scrutinizer/g/larapulse/database.svg?style=flat-square
[ico-downloads]: https://img.shields.io/packagist/dt/thephpleague/database.svg?style=flat-square[link-packagist]: https://packagist.org/packages/thephpleague/database
[link-travis]: https://travis-ci.org/larapulse/database
[link-scrutinizer]: https://scrutinizer-ci.com/g/larapulse/database/code-structure
[link-code-quality]: https://scrutinizer-ci.com/g/larapulse/database
[link-downloads]: https://packagist.org/packages/thephpleague/database
[link-author]: https://github.com/SergeyPodgornyy
[link-contributors]: ../../contributors