complex-heart/criteria

Complex Heart SDK 中用于过滤条件的 PHP 实现小工具。使用流畅接口组合多个过滤器。

v4.0.1 2024-08-14 02:56 UTC

This package is auto-updated.

Last update: 2024-09-14 03:10:42 UTC


README

Test Quality Gate Status Coverage

Complex Heart SDK 中用于过滤条件的 PHP 实现小工具。使用流畅接口组合多个过滤器。

安装

只需使用 composer 从 Packagist 安装此包

composer require complex-heart/criteria

用法

导入类并使用流畅接口

namespace ComplexHeart\Domain\Criteria;

// Match the users with status active and more than 7k followers and from Spain and France
$g1 = FilterGroup::create()        
    ->addFilterEqual('status', 1)
    ->addFilterGreaterThan('followers', 7000)
    ->addFilterIn('country', ['es', 'fr']);

$criteria = Criteria::default()
    ->withFilterGroup($g1)
    ->withOrderBy('surname')
    ->withOrderType('asc')
    ->withPageLimit(25)
    ->withPageOffset(50);

$users = $repository->match($criteria);

// alternative, same as above
$criteria = Criteria::default()
    ->withFilterGroup(FilterGroup::create()
        ->addFilterEqual('status', 1)
        ->addFilterGreaterThan('followers', 7000)
        ->addFilterIn('country', ['es', 'fr']))
    ->withOrderBy('surname')
    ->withOrderType('asc')
    ->withPageLimit(25)
    ->withPageOffset(50);

// In SQL, we may have something like:
// WHERE status = 1 AND followers >= 700 AND country in ('es', 'fr')

$users = $repository->match($criteria);

FilterGroup 是一组必须全部匹配的过滤器或条件(AND)。若要匹配一个组或另一个组(OR),只需添加更多 FilterGroup

// Match articles with given term in title, or in tagline, or in content.
$criteria = Criteria::default()
    ->withFilterGroup(FilterGroup::create()->addFilterContains('title', $term))
    ->withFilterGroup(FilterGroup::create()->addFilterContains('tagline', $term))
    ->withFilterGroup(FilterGroup::create()->addFilterContains('content', $term))
    ->withOrderBy('created_at')
    ->withOrderType(Order::TYPE_ASC)
    ->withPageNumber(3);