codemagpie / simple-query-builder
一个简单通用的查询构建器
1.2.0
2022-06-09 03:53 UTC
Requires
- php: >=7.4
- codemagpie/utils: ^1.0
- hyperf/database: ^2.2
- ruflin/elastica: ^7.1
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.1
- phpunit/phpunit: ^9.5
README
简介
一个简单通用的查询构建器,你可以使用这个构建器转换成其他查询构建器,如sql、mongodb、elasticsearch...
安装
composer require codemagpie/simple-query-builder
使用
只需扩展类 \CodeMagpie\SimpleQueryBuilder\AbstractSimpleQuery
use CodeMagpie\SimpleQueryBuilder\AbstractSimpleQuery; class UserQuery extends AbstractSimpleQuery { /** * @var string[] allow the query field, ['*'] is allow all */ protected array $fields = ['id', 'name', 'age']; }
来使用
$query = UserQuery::build() ->whereIn('id', [1, 2]) ->whereEqual('name', 'test') ->addNestedOrWhere(function ($query) { $query->whereGreat('age', 10)->orWhereLess('age', 8); }) ->orderByDesc('id') ->forPage(1, 10); // This is similar to "where id in (1, 2) and name = 'test' or (age > 10 or age < 8) order by id desc limit 10"
支持
- 支持转换 ruflin/elastica 查询,使用
$query = UserQuery::build()->whereEqual('name', 'test')->bindElasticaQueryBuilder(new \Elastica\Query());
- 支持转换 hyperf/database 查询,使用
$builder = Model::query(); // hyperf Model, such as UserModel $query = UserQuery::build()->whereEqual('name', 'test')->bindHyperfQueryBuilder($builder)