PHP Query Builder and ActiveRecord-based ORM, heavily inspired in Yii2 ORM and Eloquent (Laravel ORM), but much more compact and lightweight!
- A powerful and intuitive Query builder ("Query": the core class of the entire ORM), with the fluent and beatiful syntax you already know from Eloquent or Yii2 ORM:
$results = (new Query($myPdo))
->select('*') // not necesary
->from('users')
->where([
'name' => $submitedName, // translates to "name = ? ", where '?' will be replaced by the SQL-escaped value of $submittedPage
[ 'age', '>', $submitedAge ], // 3-elements array syntax for 'field', 'operator' and 'value'. The 3rd element will be prepared by PDO
"age < $submitedAge", //more confortable, but this way, you won't have a PDO prepared parameter
'id' => [2, 3, 6], // translates to "id IN(2, 3, 6)"
], 'OR') // OR's all the previously defined condition. Default is 'AND'
->fetchAll(); // you could also "fetchOne()"
foreach($result as $row){
// ...
}
Create a new PDO instance, and pass the instance to Query:
use ActiveORM\Query;
....
$pdo = new \PDO('mysql:dbname=goldoni;host=localhost;charset=utf8', 'root', 'root');
$query = (new Query($pdo))
Or, set the PDO globally, so that every new instance of Query uses it:
use ActiveORM\Query;
....
$pdo = new \PDO('mysql:dbname=goldoni;host=localhost;charset=utf8', 'root', 'root');
Query::setPdo($pdo);
....
$query = (new Query()) //will get the PDO instance from the global set
->select('*')
->from('users')
->where(...)
What things you need to install the software and how to install them
"require": {
"php": ">=7.2.0"
}
composer require erodriguezds/active-orm
$query = (new Query())->from('users')->select('first_name');
build the query below
SELECT first_name FROM users
$query = (new Query($this->pdo))
->insert(
'users',
[
'first_name' => ':first_name',
'last_name' => ':last_name',
'email' => ':email',
'mobile' => ':mobile',
'phone' => ':phone',
]
);
$query1 = (new Query($this->pdo))
->insert('users')
->value([
'first_name' => ':first_name',
'last_name' => ':last_name',
'email' => ':email',
'phone' => ':phone'
]);
build the query below
INSERT INTO users (first_name, last_name, email, mobile, phone) VALUES (:first_name, :last_name, :email, :mobile, :phone)
insert with ->execute()
$data = [
'id' => 12,
'first_name' => 'Joe3',
'last_name' => 'Doe3',
'email' => '[email protected]',
'phone' => '+0172222222'
];
$query = (new Query($this->pdo))
->insert(
'users',
[
'id' => ':id',
'first_name' => ':first_name',
'last_name' => ':last_name',
'email' => ':email',
'phone' => ':phone'
]
)->params($data)
->execute();
$data = [
'first_name' => 'Joe3',
'last_name' => 'Doe3',
'email' => '[email protected]'
];
$query = (new Query($this->pdo))
->update(
'users',
[
'first_name' => ':first_name',
'last_name' => ':last_name',
'email' => ':email'
],
2
)
->params($data);
$query1 = (new Query($this->pdo))
->update('users')
->set([
'first_name' => ':first_name',
'last_name' => ':last_name',
'email' => ':email'
])
->where('id = :id')
->params($data);
build the query below
UPDATE users SET first_name = :first_name, last_name = :last_name, email = :email WHERE (id = :id)
update with ->execute()
$data = [
'first_name' => 'Joe',
'last_name' => 'Doe',
'email' => '[email protected]',
'phone' => '+0172222222'
];
$query = (new Query($this->pdo))
->update(
'users',
[
'first_name' => ':first_name',
'last_name' => ':last_name',
'email' => ':email',
'phone' => ':phone'
],
4
)
->params($data)
->execute();
$query = (new Query($this->pdo))->delete('users', 2);
$query1 = (new Query($this->pdo))->delete('users')->where('id = :id')->params(['id' => 12]);
build the query below
DELETE FROM users WHERE (id = :id)
delete with ->execute()
(new Query($this->pdo))->delete('users', 2)->execute();
$query = (new Query())
->from('users', 'u')
->where('first_name = :first_name OR email = :email', 'phone = :phone');
$query2 = (new Query())
->from('users', 'u')
->where('first_name = :first_name OR email = :email')
->where('mobile = :mobile');
build the query below
SELECT * FROM users as u WHERE (first_name = :first_name OR email = :email) AND (phone = :phone)
SELECT * FROM users as u WHERE (first_name = :first_name OR email = :email) AND (mobile = :mobile)
$user = (new Query($this->pdo))
->from('users', 'u')
->where('id = :id')
->params(['id' => 1]);
$usersCount = (new Query($this->pdo))
->from('users', 'u')
->where('u.id < :number')
->params([
'number' => 5
])
->count();
$query = (new Query($this->pdo))
->from('users', 'u')
->orderBy('u.id', 'DESC');
build the query below
SELECT * FROM users as u ORDER BY u.id DESC
$query = (new Query())
->select('u.first_name', 'COUNT(id)')
->from('users', 'u')
->groupBy('u.updated_at');
build the query below
SELECT u.first_name, COUNT(id) FROM users as u GROUP BY u.updated_at
$query = (new Query())
->from('users', 'u')
->select('first_name')
->join('posts as p', 'u.id = p.user_id');
$query = (new Query())
->from('users', 'u')
->select('first_name')
->join('posts as p2', 'u.id = p2.user_id', 'inner');
build the query below
SELECT first_name FROM users as u LEFT JOIN posts as p ON u.id = p.user_id
SELECT first_name FROM users as u INNER JOIN posts as p2 ON u.id = p2.user_id
$query = (new Query($this->pdo))
->from('users', 'u')
->where('first_name = :first_name OR email = :email')
->limit(5);
build the query below
SELECT * FROM users as u WHERE (first_name = :first_name OR email = :email) LIMIT 0, 5
$query = (new Query($this->pdo))->from('users')->select('first_name')->fetchAll();
$user = (new Query($this->pdo))
->from('users', 'u')
->where('id = :id')
->params(['id' => 1])
->fetch();
$user = (new Query($this->pdo))
->from('users', 'u')
->where('id = :id')
->params(['id' => 100])
->fetchOrFail();
$query = (new Query($this->pdo))
->insert(
'users',
[
'first_name' => ':first_name',
'last_name' => ':last_name',
'email' => ':email',
'mobile' => ':mobile',
'phone' => ':phone',
]
)
->execute();
$paginate = (new Query($this->pdo))
->from('users', 'u')
->into(Demo::class)
->paginate(5, 1);
$paginate->getNbPages();
$paginate->haveToPaginate();
$paginate->hasPreviousPage();
$paginate->getPreviousPage();
$paginate->hasNextPage();
$paginate->getNextPage();
$paginate->getCurrentPageOffsetStart();
$paginate->getCurrentPageOffsetEnd();
$paginate->getIterator(); // return collections of objects
use Goldoni\Builder\Entities\Demo;
...
$demos = (new Query($this->pdo))
->from('users', 'u')
->into(Demo::class)
->fetchAll();
$demo1 = $demos[0];
// get_class($demo1) === Demo::class
echo $demo1->firstName;
$demo2 = (new Query($this->pdo))
->from('users', 'u')
->where('id = :id')
->into(Demo::class)
->params(['id' => 2])
->fetch();
// get_class($demo2) === Demo::class
echo $demo2->firstName;
var_dump($demo1 instanceof Demo::class); // TRUE
var_dump($demo2 instanceof Demo::class); // TRUE
./vendor/bin/phpunit
We use 1.3.0
- Goldoni Fouotsa - Initial work
This project is licensed under the MIT License