pass array of conditions to doctrine expr()-gt;orx() method(将条件数组传递给 dotric expr()-orx() 方法)
问题描述
我需要像这样用 QueryBuilder
构建 DQL
I need to construct DQL with a QueryBuilder
like this
[QUERY]... AND WHERE e.type = x OR e.type = Y OR e.type = N [...]
我在数组中有类型如何将这个数组传递给我的查询构建器?
I have types in array How can I pass this array to my query builder?
$qb->andWhere($qb->expr()->orx(CONDITIONS));
类型列表将是动态的,在每个 foreach 类型循环上调用 $qb->andWhere
只会产生更多 AND WHERE 没有更多的 OR.
我可以存储多个orx
表达式,然后将其添加到andWhere
吗?知道如何解决这个可能是常见的问题吗?
List of types will be dynamic, calling $qb->andWhere
on each foreach types loop will make only more AND WHERE's no more ORs.
Can I store multiply orx
expressions and then add it to andWhere
? Any idea how to solve this, probably, common problem?
推荐答案
我知道 tommarow 会是美好的一天.解决方法很简单.您可以像这样制作 OR 表达式数组
I knew that tommarow gonna be a better day. The solution is simple. Your can make array of OR expressions like so
$ors[] = $qb->expr()->orx('e.type = '.$qb->expr()->literal($value));
然后只需通过 join 方法将其添加到查询构建器的 andWhere()/Where() 方法中,如下所示:
And then just add it to andWhere()/Where() method of the query builder via join method like so:
$qb->andWhere(join(' OR ', $ors));
这篇关于将条件数组传递给 dotric expr()->orx() 方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:将条件数组传递给 dotric expr()->orx() 方法
基础教程推荐
- phpmyadmin 错误“#1062 - 密钥 1 的重复条目‘1’" 2022-01-01
- PHP 守护进程/worker 环境 2022-01-01
- 如何在 XAMPP 上启用 mysqli? 2021-01-01
- Doctrine 2 - 在多对多关系中记录更改 2022-01-01
- 在 CakePHP 2.0 中使用 Html Helper 时未定义的变量 2021-01-01
- 使用 PDO 转义列名 2021-01-01
- 找不到类“AppHttpControllersDB",我也无法使用新模型 2022-01-01
- HTTP 与 FTP 上传 2021-01-01
- 如何在 Symfony 和 Doctrine 中实现多对多和一对多? 2022-01-01
- 在 yii2 中迁移时出现异常“找不到驱动程序" 2022-01-01