maxim-oleinik / blade-database
PHP Database interface library
Installs: 2 517
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: >=7.0
Requires (Dev)
- ext-mysqli: *
- ext-pdo: *
- ext-pgsql: *
- phpunit/phpunit: 6.*
README
Универсальный адаптер к любому уже реализованному коннекту к БД.
Install
-
Add to
composer
composer require maxim-oleinik/blade-database
-
Implement
\Blade\Database\DbConnectionInterface
Реализовать "мост" между своим коннектом к базе и этим Адаптеромclass MyDbConnection implements \Blade\Database\DbConnectionInterface { ->execute($sql, $bindings = []): int; ->each($sql, $bindings = []): Generator; ->escape($value): string ->beginTransaction(); ->commit(); ->rollBack(); }
Или использовать готовый:
// PDO $dsn = sprintf('mysql:host=%s;port=%d;dbname=%s', $host, $port, $dbName); $connection = new \Blade\Database\Connection\PdoConnection($dsn, $user, $pass, [ \PDO::ATTR_ERRMODE => \PDO::ERRMODE_EXCEPTION, \PDO::ATTR_DEFAULT_FETCH_MODE => \PDO::FETCH_ASSOC, ]);
// PostgreSQL (pgsql) $dsn = sprintf('host=%s port=%d dbname=%s user=%s password=%s', $host, $port, $dbName, $user, $pass ); $connection = new \Blade\Database\Connection\PostgresConnection($dsn, PGSQL_CONNECT_FORCE_NEW);
// MySQL (mysqli) $connection = new \Blade\Database\Connection\MysqlConnection( $host, $user, $pass, $dbName, $port );
DbAdapter
Класс представляет собой универсальную обертку над любым коннектом к БД.
И реализует набор вспомогательных методов для выборки из базы.
$db = new DbAdapter(new MyDbConnection);
->execute($query, array $bindings = []): int - Кол-во затронутых строк
->each($query, array $bindings = []): Generator - Построчная выборка
->selectAll($query, array $bindings = []): array - Выбрать всю выборку в один массив
->selectRow($query, array $bindings = []): array - Выбрать одну строку
->selectColumn($query, array $bindings = []): array - Выбрать значение 1 колонки в массив
->selectValue($query, array $bindings = []): string - Выбрать единственное значение
->selectKeyValue($query, array $bindings = []): array - Выбрать значения 2ух колонок в ассоциативный массив col1 => $col2
->chunk($pageSize, SqlBuilder $sql, callable $handler) - Разбить выборку на части и вызвать $handler(array $rows) для каждой
->beginTransaction();
->commit();
->rollBack();
->transaction(callable $func)
->getConnection(): \Blade\Database\DbConnectionInterface
SqlBuilder
Настройка
\Blade\Database\Sql\SqlBuilder::setEscapeMethod(function($value) {
return pg_escape_string($value);
});
// или
\Blade\Database\Sql\SqlBuilder::setEscapeMethod([$connection, 'escape']);
Select
Автоматическое экранирование значений производится в where-условиях
$sql = SqlBuilder::make('comment label')
->select("id, code, sum(code) as codes")
->addSelect("name")
->from("my_table", $alias = 't')
->setFromAlias('t')
->addJoin("LEFT JOIN authors AS a ON (a.id=t.author_id)")
->andWhere("t.id = %d", 123)
->andWhereEquals("t.id", 123) // t.id='123'
->andWhereNotEquals("t.id", 123) // t.id<>'123'
->andWhereEquals("t.id", null) // t.id IS NULL
->andWhere("a.name > '%s'", 'some text') // sprintf escaped values
->andWhereIn("t.code", [1,2,3])
->andWhereNotIn("t.code", [4,5])
->orderBy("id ASC, code")
->addOrder("name DESC")
->groupBy("t.code")
->having("sum(code) > 10")
->limit(10, $offset = 20);
echo $sql;
Подстановка Алиасов в колонки
$sql->setFromAlias('t')
->andWhere($sql->col('id') . '=1') // "t.id=1"
->select($sql->col(['id', 'name'])) // "t.id, t.name"
Join
// Raw SQL join
$sql = SqlBuilder::make()
->addJoin("LEFT JOIN authors AS a ON (a.id=t.author_id)")
// !!! при использовании join() - обязательно явно указывать select()
->select('t.*, a.id')
->andWhere("a.name > '%s'", 'some text');
// Объединение 2ух запросов в Join
$sqlAuthors = SqlBuilder::make()->from('authors', 'a')
->andWhere("a.name > '%s'", 'some text');
$sql = SqlBuilder::make()->from("my_table", 't')
->innerJoin($sqlAuthors, 'ON (a.id=t.author_id)')
->leftJoin($sqlAuthors, 'USING author_id')
->rightJoin($sqlAuthors)
// Универсальный метод
->join('FULL OUTER JOIN', $sqlAuthors, 'ON (...)')
// !!! при использовании join() - обязательно явно указывать select()
->select('t.*')
Подстановка count()
SqlBuilder::make()
->from("my_table")
->count($fields = '*');
// SELECT count(*) FROM my_table
exists() = SELECT 1
SqlBuilder::make('comment label')
->from("my_table")
->andWhere('...')
->exists(); // 1, если записи существуют
// SELECT 1 FROM my_table WHERE ... LIMIT 1
SELECT FROM (SELECT ...)
$subSql = SqlBuilder::make()
->from("some_tabe")
->andWhere('...')
SqlBuilder::make()
->select('t.id')
->from($subSql, 't')
// SELECT t.id FROM (SELECT * FROM some_tabe WHERE ...) AS t
Insert
SqlBuilder::make()
->insert("my_table")
->values([
'code' => 5,
'name' => 'some text',
])
->returning('id, code');
// INSERT INTO my_table (code, name) VALUES (5, 'some text') RETURNING id, code
Вставка нескольких строк
SqlBuilder::make()
->insert("my_table")
->batchMode()
->values([
[
'code' => 5,
'name' => 'some text',
],
[
'code' => 6,
'name' => 'some text',
],
]);
// INSERT INTO my_table (code, name) VALUES (5, 'some text'), (6, 'some text')
Update
SqlBuilder::make()
->update("my_table")
->andWhere("id = %d", 123)
->values([
'code' => 5,
'name' => 'some text',
]);
// UPDATE my_table SET code=5, name='some text' WHERE id = 123
Delete
SqlBuilder::make()
->delete("my_table")
->andWhere("id = %d", 123);
// DELETE FROM my_table WHERE id = 123