How do I use a complex criteria inside a doctrine 2 entity#39;s repository?(如何在学说 2 实体的存储库中使用复杂标准?)
问题描述
假设我有一张包含节日信息的表格.
每个节日都有开始和结束日期.
Lets say I have a table that holds information about festivals.
Each festival has a start and end date.
我想选择在给定日期直播(发生)的所有节日.
I want to select all the festivals that are live (that happen) on a given date.
意思是,我想选择所有节日,它们的开始日期早于或在给定日期,而结束日期在同一给定日期之后或之后.
Meaning, I want to select all the festivals that their start date is before or on a given date, and that their end date is after or on a the same given date.
所以我继续到节日实体的存储库类,并创建了一个方法来做到这一点.
但是标准参数findBy"expects 是一个数组,所有示例仅将其视为简单标准(例如,array('name' => 'billy')"将选择 name 列中具有 billy 值的所有行),其中仅使用比较运算符.
So I went on to the repository class of the festival entity, and created a method to do just that.
But the criteria argument "findBy" expects is an array, which all the examples only treat as a simple criteria (e.g. "array('name' => 'billy')" will select all the rows that have the value billy in their name column), which uses only the comparison operator.
如何使用其他运算符,例如
How can I use other operators such as
>, <, !=, IN, NOT IN, LIKE
等等?
推荐答案
如果你想要特定的东西,你需要编写自己的查询(可能使用 DQL).我相信如果您的具体标准较少,内置的findBy"方法更适合快速抓取对象.我不知道您的实体名称或它们的存储位置.在您的节日存储库中可能是这样的功能.
You'll need to write your own query (probably using DQL) if you want something that specific. I believe the built in "findBy" methods are more for just grabbing objects quickly if you have less specific criteria. I don't know your entity names or where they are stored. Could be something like this as a function in your Festival Repository.
public function findActiveFestivals($start, $end)
{
$qb = $this->_em->createQueryBuilder();
$qb->select('f')
->from('Festival', 'f')
->where('f.start >= :start')
->andWhere('f.end <= :end')
->setParameters(array('start' => $start, 'end' => $end));
return $qb->getQuery()->getArrayResult();
}
这篇关于如何在学说 2 实体的存储库中使用复杂标准?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何在学说 2 实体的存储库中使用复杂标准?
基础教程推荐
- 在多维数组中查找最大值 2021-01-01
- mysqli_insert_id 是否有可能在高流量应用程序中返回 2021-01-01
- WooCommerce 中选定产品类别的自定义产品价格后缀 2021-01-01
- 超薄框架REST服务两次获得输出 2022-01-01
- 如何在 PHP 中的请求之间持久化对象 2022-01-01
- 在 Woocommerce 中根据运输方式和付款方式添加费用 2021-01-01
- XAMPP 服务器不加载 CSS 文件 2022-01-01
- 通过 PHP SoapClient 请求发送原始 XML 2021-01-01
- 在 PHP 中强制下载文件 - 在 Joomla 框架内 2022-01-01
- Libpuzzle 索引数百万张图片? 2022-01-01