如何使用 Doctrine 2 中的 MySQL 的 FIELD 函数对结果进行排序?

Linda Hamilton
发布: 2024-10-30 00:07:02
原创
862 人浏览过

How to Order Results Using MySQL's FIELD Function in Doctrine 2?

在 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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!