doctrine:QueryBuilder vs createQuery?

nev*_*ame 67 doctrine-orm

在Doctrine中,您可以通过两种方式创建DQL:

EntityManager :: createQuery:

$query = $em->createQuery('SELECT u FROM MyProject\Model\User u WHERE u.id = ?1');
Run Code Online (Sandbox Code Playgroud)

QueryBuilder:

$qb->add('select', 'u')
   ->add('from', 'User u')
   ->add('where', 'u.id = ?1')
   ->add('orderBy', 'u.name ASC');
Run Code Online (Sandbox Code Playgroud)

我想知道区别是什么,我应该使用哪个?

jac*_*avo 65

  1. DQL更容易阅读,因为它与SQL非常相似.如果您不需要根据一组参数更改查询,这可能是最佳选择.

  2. 查询生成器是构造查询的API,因此如果需要动态构建查询(如迭代一组参数或过滤器),则更容易.您不需要执行任何字符串操作来构建查询,例如join,split等等.

  • 是的,QueryBuilder为您创建DQL字符串.之后,无论如何都要解析DQL. (4认同)

Mar*_*čka 33

查询构建器就是说,创建查询的界面...使用起来应该更舒服,它不仅有add()方法,还有where(),Where(),from()等方法但最后,它只是编写了一个类似于你在createQuery()方法中使用的查询.

更高级使用查询构建器的示例:

$em->createQueryBuilder()
            ->from('Project\Entities\Item', 'i')
            ->select("i, e")
            ->join("i.entity", 'e')
            ->where("i.lang = :lang AND e.album = :album")
            ->setParameter('lang', $lang)
            ->setParameter('album', $album);
Run Code Online (Sandbox Code Playgroud)


Vin*_*ler 13

他们有不同的目的:

  • 当您知道完整查询时,DQL更易于使用.
  • 当您必须根据某些条件,循环等构建查询时,查询构建器会更智能.