koine/query-builder

查询构建器 - 使SQL构建更简单

0.9.7 2014-09-15 14:43 UTC

This package is not auto-updated.

Last update: 2024-09-14 16:00:28 UTC


README

查询构建器,简化SQL构建

代码信息

Build Status Coverage Status Code Climate Scrutinizer Code Quality

包信息

Latest Stable Version Total Downloads Latest Unstable Version License Dependency Status

安装

通过Composer安装

将lib添加到你的composer.json文件中的require键。

{
    // composer.json
    // [..]
    require: {
        // append this line to your requirements
        "koine/query-builder": "dev-master"
    }
}

替代安装

  • 学习 composer。您不需要寻找替代安装。这是值得的。请相信我 ;-)
  • 按照 以下说明 操作

用法

SELECT

这是一个选择查询的示例。

$fields = array('u.name AS name', 'r.name AS role');

// Selecting via factory
$select = Koine\QueryBuilder::factorySelect($fields);

// Selecting via the select method
$select = Koine\QueryBuilder::factorySelect()
    ->select($fields);

// or alternatively
$select = new Koine\QueryBuilder\Statements\Select();
$select->select($fields);

// From
$select->from('users u');

// Adding joins
$select->innerJoin('roles r', 'u.id = r.user_id');

$select->toSql();

// SELECT u.name AS name, r.name AS role 
// FROM users u INNER JOIN roles r ON u.idi = r.user_id

INSERT

// Using the factory
$insert = Koine\QueryBuilder::insert();

// Or alternatively
$insert = new Koine\QueryBuilder\Statements\Insert();

$insert->into('users')->values(array(
    'name'  => 'Jon Doe',
    'email' => 'jon@doe.com'
));

$insert->toSql();

// INSERT INTO users (name, email) VALUES ('Jon Doe', 'jon@doe.com');

UPDATE

$update = Koine\QueryBuilder::update('users');

// or
$update = new Koine\QueryBuilder\Statements\Update;
$update->table('users');

// setting values and conditions

$update->set(array(
        'enabled' => 1
    ))->where('email', ':email');

$update->toSql(array(
    'email' => 'admin@email.com'
));

// UPDATE users SET enabled = 1 WHERE email = 'admin@email.com'

DELETE

待实现:实现

WHERE

每次调用 where() 方法时,条件都会添加到查询中。

// method signature
$query->where($field, $value, $operator);

// or
$query->where($condition);

// or
$query->where(array(
    array($field, $value, $operator),
    array($condition),
));

// Below some valid examples:

$query->where('email', 'admin@abc.com');
// WHERE email = 'admin@abc.com'

$query->where('email', 'admin@abc.com', '<>');
// WHERE email <> "admin@abc.com"

$query->where('email', '%@google.com', 'LIKE');
// WHERE email LIKE "%@google.com"

$query->where('age', 20);
// WHERE age = 20

$query->where('code', 001);
// WHERE code = 001

$query->where('code', array('value' => '001'));
// WHERE code = '001'

$query->where('(code = 1 OR code = 2)'));
// WHERE (code = 1 OR code = 2)

// multiple conditioins, one method call
$query->where(array(
    array('email', 'admin@abc.com', '<>'),
    array('email', '%@google.com', 'LIKE'),
    array('age', 20),
    array('(code = 1 OR code = 2)'),
    array('hash', array('value' => 'SOMEFUNCTION()')),
));

// WHERE condition 1 AND condition 2..

ORDER BY

$query->orderBy('name DESC');
// or
$query->orderBy(array('name DESC', 'age ASC'));

GROUP BY

$query->groupBy('a, b, c');
// or
$query->groupBy(array('a', 'b', 'b'));

LIMIT

$query->limit(2);
$query->limit(2, 1);

使用占位符

当您不知道将要使用哪些值时(因为它们依赖于尚未执行的查询的结果,例如),占位符是构建查询的好方法。

$insert->into('users')->values(array(
    'name'  => ':name',
    'email' => ':email'
));

$insert->toSql(array(
    'name'  => 'Jon Doe',
    'email' => 'jon@doe.com'
));

// INSERT INTO users (name, email) VALUES ('Jon Doe', 'jon@doe.com');

问题/功能建议

这里 是问题跟踪器。

贡献

只接受TDD代码。请遵循 PSR-2代码规范

  1. 分叉它
  2. 创建您的功能分支(git checkout -b my-new-feature
  3. 提交您的更改(git commit -am '添加某些功能'
  4. 推送到分支(git push origin my-new-feature
  5. 创建新的Pull Request

如何运行测试

phpunit --configuration tests/phpunit.xml

要检查代码规范,请运行

phpcs --standard=PSR2 lib
phpcs --standard=PSR2 tests

# alternatively

./bin/travis/run_phpcs.sh

许可

MIT

作者