gonzalo123 / db
Database Abstraction Layer over DBAL
dev-master
2013-12-23 13:30 UTC
Requires
- doctrine/dbal: 2.4.x-dev
Requires (Dev)
- phpunit/phpunit: 3.7.28
This package is not auto-updated.
Last update: 2025-01-14 03:28:58 UTC
README
First we set up de DBAL connection
use Doctrine\DBAL\DriverManager; // Set up DBAL Connection $conn = DriverManager::getConnection([ 'driver' => 'pdo_sqlite', 'memory' => true ]);
We also can set up the DBAL connection from a PDO instance
$conn = DriverManager::getConnection(['pdo' => new PDO('sqlite::memory:')]);
Then we create the database and populate tables with dummy data
// init database $conn->exec("CREATE TABLE users ( userid VARCHAR PRIMARY KEY NOT NULL , password VARCHAR NOT NULL , name VARCHAR, surname VARCHAR );"); $conn->exec("INSERT INTO users VALUES('user','pass','Name','Surname');"); $conn->exec("INSERT INTO users VALUES('user2','pass2','Name2','Surname2');");
Now we can use the library:
use G\Sql; use G\Db; // setting up G\Db with connection $db = new Db($conn); // select from string $data = $db->select("select * from users"); // select from table $data = $db->select(SQL::createFromTable("users")); // select from table with where clause $data = $db->select(SQL::createFromTable("users", ['userid' => 'user2'])); // iterating select statement changing the recordset $data = $db->select(SQL::createFromTable("users"), function (&$row) { $row['name'] = strtoupper($row['name']); }); // transactions $db->transactional(function (Db $db) { $userId = 'temporal'; $db->insert('users', [ 'USERID' => $userId, 'PASSWORD' => uniqid(), 'NAME' => 'name3', 'SURNAME' => 'name3' ]); $db->update('users', ['NAME' => 'updatedName'], ['USERID' => $userId]); $db->delete('users', ['USERID' => $userId]); });