Regex with Doctrine 2 query builder?

前端 未结 4 1264
故里飘歌
故里飘歌 2020-12-10 12:38

As per the title, how would one match on a regular expression with the Doctrine 2 query builder? Basically I\'m trying to generate unique slugs.

Here is my current

相关标签:
4条回答
  • 2020-12-10 13:00

    Not tested (for MySQL):

    $qb->where(new Doctrine\ORM\Query\Expr\Comparison(
        'o.slug', 'REGEXP', ':slug')
    );
    $qb->setParameter('slug', '^'.$slug->__toString().'-[[:digit:]]+$');
    
    0 讨论(0)
  • 2020-12-10 13:07

    REGEXP is a vendor specific function so Doctrine itself doesn't support it. Plus it's not a function so much as a comparison operator (see this answer). But you can use the function on the field to compare with another value. DoctrineExtensions (written by a contributor to doctrine) has code to enable regular expression in MySQL.

    Example from the File:

    $query = $this->getEntityManager()->createQuery('SELECT A FROM Entity A WHERE REGEXP(A.stringField, :regexp) = 1');
    $query->setParameter('regexp', '^[ABC]');
    $results = $query->getArrayResult();
    

    If you don't want to use DoctrineExtensions, you can write your own by following this blog post, or you can look at the code for this Doctrine extension and write your own custom DQL function.

    I have confirmed that REGEXP using DoctrineExtensions works great for my needs!

    0 讨论(0)
  • 2020-12-10 13:09

    install the DoctrineExtensionsBundle:

    composer require beberlei/doctrineextensions
    

    add the REGEXP configuration - update your app/config.yml

    doctrine:
        orm:
            dql:
                string_functions:
                    regexp: DoctrineExtensions\Query\Mysql\Regexp
    

    where ever your QueryBuilder is do this:

    $qb = $this->createQueryBuilder('x');
    
    return $qb->andWhere('REGEXP(x.your_property, :regexp) = true')
              ->setParameter('regexp', '[[:digit:]]{3}') // insert your own regex here
              ->getQuery()->getResult();
    

    and don't forget to use SQL compatible regexes

    0 讨论(0)
  • 2020-12-10 13:18

    I did like this

     $query->andWhere('REGEXP(r.status, :text) = 1')
           ->orWhere('REGEXP(r.comment, :text) = 1')
           ->setParameter('text',MY REGULAR EXP);
    
    0 讨论(0)
提交回复
热议问题