PDO
Just another PDO database library
Installation
Use Composer
$ composer require faapz/pdo
Usage
Examples selecting, inserting, updating and deleting data from or into users
table.
require_once 'vendor/autoload.php';
$dsn = 'mysql:host=your_db_host;dbname=your_db_name;charset=utf8';
$usr = 'your_db_username';
$pwd = 'your_db_password';
$database = new FaaPz\PDO\Database($dsn, $usr, $pwd);
// SELECT * FROM users WHERE id = ?
$select = $database->select()
->from('users')
->where(new FaaPz\PDO\Clause\Conditional('id', '=', 1234));
if ($insert->execute()) {
$data = $stmt->fetch();
}
// INSERT INTO users (id , username , password) VALUES (? , ? , ?)
$insert = $database->insert(
'id',
'username',
'password'
)
->into('users')
->values(
1234,
'user',
'passwd'
);
if ($insert->execute()) {
$insertId = $database->lastInsertId();
}
// UPDATE users SET pwd = ? WHERE id = ?
$update = $database->update(["pwd" => "your_new_password"])
->table("users")
->where(new FaaPz\PDO\Clause\Conditional("id", "=", 1234));
if (($result = $insert->execute()) !== false) {
$affectedRows = $result->rowCount();
}
// DELETE FROM users WHERE id = ?
$delete = $database->delete()
->from("users")
->where(new FaaPz\PDO\Clause\Conditional("id", "=", 1234));
if (($result = $delete->execute()) !== false) {
$affectedRows = $result->rowCount();
}
The
sqlsrv
extension will fail to connect when using error modePDO::ERRMODE_EXCEPTION
(default). To connect, you will need to explicitly passarray(PDO::ATTR_ERRMODE => PDO::ERRMODE_WARNING)
(orPDO::ERRMODE_SILENT
) into the constructor, or override thegetDefaultOptions()
method when usingsqlsrv
.
Documentation
See DOCUMENTATION
Changelog
See CHANGELOG
License
See LICENSE