5

是否可以创建搜索过滤器来搜索不是从一个字段,而是从CONCAT(name, description)

protected function configureDatagridFilters(DatagridMapper $datagridMapper)
{
    $datagridMapper->add('search');
}
4

3 回答 3

5

我找到了学说_orm_callback 类型的解决方案

protected function configureDatagridFilters(DatagridMapper $datagridMapper)
{


    $datagridMapper
        ->add( 'text', 'doctrine_orm_callback', array(
            'callback' => array($this, 'getSearchFilter'),
            'field_type' => 'text'
        ) );
}

public function getSearchFilter($queryBuilder, $alias, $field, $value) {
    if (!$value['value']) {
        return;
    }

    $exp = new \Doctrine\ORM\Query\Expr();
    $queryBuilder->andWhere($exp->like($exp->concat($alias.'.name', $alias.'.description'), $exp->literal('%' . $value['value'] . '%')));

    return true;
}    
于 2013-01-31T13:37:48.147 回答
2

@Liutas 的绝佳解决方案!

如果您只想使用concat作为解决方法来搜索多个字段,您可以使用以下代码:

public function getFullTextFilter($queryBuilder, $alias, $field, $value)
{
    if (!$value['value']) {
        return;
    }

    $queryBuilder->andWhere($queryBuilder->expr()->orX(
        $queryBuilder->expr()->like($alias.'.name', $queryBuilder->expr()->literal('%' . $value['value'] . '%')),
        $queryBuilder->expr()->like($alias.'.description', $queryBuilder->expr()->literal('%' . $value['value'] . '%')),
        $queryBuilder->expr()->like($alias.'.anotherfield', $queryBuilder->expr()->literal('%' . $value['value'] . '%'))
    ));

    return true;
}
于 2014-09-17T11:57:08.830 回答
1

根据@webDEVILopers 的回答,这是一个可用于任何字段的通用类:

use Doctrine\ORM\Query\Expr;
use Sonata\AdminBundle\Datagrid\ProxyQueryInterface;
use Sonata\DoctrineORMAdminBundle\Filter\BooleanFilter;

class MultiStringFilter extends BooleanFilter
{
    /**
     * @param string $field should be in the form field1-field2-…-fieldn
     */
    public function filter(ProxyQueryInterface $queryBuilder, $alias, $field, $data)
    {
        $fields = explode('-', $field);
        $filterActive = $data['value'];
        if ($filterActive === null) {
            return;
        }

        $subConditions = [];
        foreach ($fields as $field) {

            $subConditions[] = $queryBuilder->expr()->like(
                "LOWER($alias.$field)",
                $queryBuilder->expr()->literal('%' . strtolower($data['value']) . '%')
            );
        }

        if (count($subConditions) > 1) {
            $queryBuilder->andWhere(new Expr\Orx($subConditions));
        }
    }
}
于 2016-01-18T14:50:22.047 回答