定制 saf/doctrine-orm-searchable-repository 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

saf/doctrine-orm-searchable-repository

最新稳定版本:0.2.2

Composer 安装命令:

composer require saf/doctrine-orm-searchable-repository

包简介

Make your Doctrine's EntityRepository Searchable

README 文档

README

This library extends the EntityRepository to add search functionality with a lot of filters.

$filters = [
    'name'        => ['neq' => 'My name'],
    'author.name' => ['in' => ['Foo', 'Bar']],
    'rating'      => ['gte' => 4],
];

$orders = [
    'author.name' => 'ASC',
    'name'        => 'DESC',
];

$entities = $repository->search($filters, $orders);

You can even perform search of a value on multiple columns:

$filters = [
    'name' => [
        'field'     => ['firstName', 'lastName],
        'condition' => 'like',
        'value'     => '%Lewis%',
    ],
];

$orders = [
    'author.name' => 'ASC',
    'name'        => 'DESC',
];

$entities = $repository->search($filters, $orders);

This will result in the following condition :

firstName like '%Lewis%' OR lastName like '%Lewis%'

How to use

Install using composer

composer require saf/doctrine-orm-searchable-repository

And just make your repository class extends SAF\SearchableRepository\SearchableRepository.

use SAF\SearchableRepository\SearchableRepository;

class MyRepository extends  SearchableRepository
{
    // ...
}

Then you can access the search method on your repository.

Filters

This library use filter types to handle how to apply filter condition and ordering. It comes with a GenericType that is the default one but you can add a new filter type.

// add a new type handler to your search with the setType function
// the first parameter correspond to the doctrine type
// the second parameter is the filter type (that must implements \SAF\SearchableRepository\SearchableRepository\Types\TypeInterface interface)
$repository->setType('string', new MyStringFilterType());

GenericType

Filter Supported value Behavior
eq mixed Filter elements that match the given value
neq mixed Filter elements that not match the given value
lt mixed Filter elements with value less than the given value
lte mixed Filter elements with value less than or equals the given value
gt mixed Filter elements with value greater than the given value
gte mixed Filter elements with value greater than or equals the given value
like string Use a LIKE statement to filter elements
not_like string Use a NOT LIKE statement to filter elements
null boolean true: filter elements with a null value false : filter elements with a non-null value
not_null boolean true: filter elements with a non-null value false: filter elements with a null value
in array Filter elements with value in the given array
not_in array Filter elements with value not in the given array

统计信息

  • 总下载量: 10.7k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2017-02-20