erodriguezds/active-orm
Composer 安装命令:
composer require erodriguezds/active-orm
包简介
Yet another lightweight ActiveRecord ORM for PHP library is responsible for building SQL query strings, Paginate and Hydration via an object oriented PHP interface.
README 文档
README
PHP Query Builder and ActiveRecord-based ORM, heavily inspired in Yii2 ORM and Eloquent (Laravel ORM), but much more compact and lightweight!
Features
- 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:
Select Query
$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){ // ... }
Getting Started
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(...)
Prerequisites
What things you need to install the software and how to install them
"require": {
"php": ">=7.2.0"
}
Installing
composer require erodriguezds/active-orm
Examples
select
$query = (new Query())->from('users')->select('first_name');
build the query below
SELECT first_name FROM users
insert
$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' => 'joe@contact.de', '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();
update
$data = [ 'first_name' => 'Joe3', 'last_name' => 'Doe3', 'email' => 'joe@contact.de' ]; $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' => 'joe@contact.de', '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();
delete
$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();
where
$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)
params
$user = (new Query($this->pdo)) ->from('users', 'u') ->where('id = :id') ->params(['id' => 1]);
count
$usersCount = (new Query($this->pdo)) ->from('users', 'u') ->where('u.id < :number') ->params([ 'number' => 5 ]) ->count();
orderBy
$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
groupBy
$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
joins
$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
limit
$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
fetchAll
$query = (new Query($this->pdo))->from('users')->select('first_name')->fetchAll();
fetch
$user = (new Query($this->pdo)) ->from('users', 'u') ->where('id = :id') ->params(['id' => 1]) ->fetch();
fetchOrFail
$user = (new Query($this->pdo)) ->from('users', 'u') ->where('id = :id') ->params(['id' => 100]) ->fetchOrFail();
execute
$query = (new Query($this->pdo)) ->insert( 'users', [ 'first_name' => ':first_name', 'last_name' => ':last_name', 'email' => ':email', 'mobile' => ':mobile', 'phone' => ':phone', ] ) ->execute();
paginate
$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
Hydration
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
Unit Test
./vendor/bin/phpunit
Versioning
We use 1.3.0
Authors
- Goldoni Fouotsa - Initial work
License
This project is licensed under the MIT License
统计信息
- 总下载量: 4
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2019-05-21