在 Doctrine 2 中通过 MySQL FIELD 函数排序
Doctrine 2 本身不支持开箱即用的 MySQL FIELD 函数。要利用它,您可以利用扩展提供的自定义字符串函数。
DoctrineExtensions 解决方案:
DoctrineExtensions 库包含一个名为“FIELD”的自定义字符串函数,该函数模拟MySQL 字段函数。要实现此功能,请添加以下配置:
<code class="php">$doctrineConfig = $this->em->getConfiguration(); $doctrineConfig->addCustomStringFunction('FIELD', 'DoctrineExtensions\Query\Mysql\Field');</code>
用法:
FIELD 函数可以在 SELECT、WHERE 和 BETWEEN 子句中使用。虽然它不能直接在 ORDER BY 中使用,但解决方法是在 SELECT 子句中添加一个附加字段并按该字段排序:
<code class="php">$qb ->select("r, field(r.id, " . implode(", ", $ids) . ") as HIDDEN field") ->from("Entities\Round", "r") ->where($qb->expr()->in("r.id", $ids)) ->orderBy("field");</code>
通过在 SELECT 子句中指定 HIDDEN,您可以避免出现附加字段出现在结果行中。这允许您使用 Doctrine 2.2 在 IN 表达式中有效地对值进行排序。
以上是如何使用 Doctrine 2 中的 MySQL 的 FIELD 函数对结果进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!