codemagpie/simple-query-builder

一个简单通用的查询构建器

1.2.0 2022-06-09 03:53 UTC

This package is auto-updated.

Last update: 2024-09-09 08:32:56 UTC


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"

支持

  1. 支持转换 ruflin/elastica 查询,使用
$query = UserQuery::build()->whereEqual('name', 'test')->bindElasticaQueryBuilder(new \Elastica\Query());
  1. 支持转换 hyperf/database 查询,使用
$builder =  Model::query(); // hyperf Model, such as UserModel
$query = UserQuery::build()->whereEqual('name', 'test')->bindHyperfQueryBuilder($builder)