QueryBuilder 与 createQuery的区别是什么?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (268)

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

EntityManager::createQuery:

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

QueryBuilder:

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

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

提问于
用户回答回答于

可以说,查询构建器就是用来创建查询的接口,它应该更舒适一点,它不仅具有add()方法,而且还具有诸如where(),andWhere(),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);
用户回答回答于
  1. DQL更容易阅读,因为它与SQL非常相似。如果你不需要根据一组参数更改查询,则这可能是最佳选择。
  2. 查询生成器是构建查询的api,因此,如果需要动态构建查询,比如迭代一组参数或过滤器,则查询生成器会更容易。你不需要执行任何字符串操作来构建查询,如连接,分割或其他任何操作。

所属标签

可能回答问题的人

  • 天使的炫翼

    17 粉丝531 提问9 回答
  • 优惠活动秘书

    0 粉丝2 提问8 回答
  • 最爱开车啦

    8 粉丝503 提问6 回答
  • 富有想象力的人

    3 粉丝0 提问5 回答

扫码关注云+社区

领取腾讯云代金券