1

我想知道如何格式化这个查询。我有一个包含三个日期的表格,其中一些日期可以为空。这三个字段是createdDate、downDate 和fixDate。我需要根据日期查询并获取最新条目。例如,如果 fixDate 不为 null,则按 fixDate 排序,如果为 null,则我需要按 downDate 排序。如果downDate 为空,那么我按createdDate 排序。

通过 mySQL,我得到了正确的结果:

SELECT * FROM history WHERE equipment_id=88 ORDER BY IF(ISNULL(fix_date), IF(ISNULL(down_date), created_date, down_date), fix_date) DESC;

我正在尝试将其放入我的 grails 项目并使用 HQL 并尝试过(也尝试过其他变体):

History.executeQuery("SELECT FROM History WHERE equipment=:eqpt ORDER BY " +
"IF(ISNULL(fixDate), IF(ISNULL(downDate), createdDate, downDate), fixDate) DESC", [eqpt:equipment])

也试过:

   History.executeQuery("SELECT FROM History WHERE equipment=:eqpt ORDER BY " +
    "IF(COALESCE(fixDate,downDate,createdDate) DESC", [eqpt:equipment])

我得到的错误是:

nexpected token: FROM near line 1, column 8 [SELECT FROM com...History WHERE equipment=:eqpt ORDER BY IF(COALESCE(fixDate, downDate, createdDate) DESC]

我很感激任何帮助,如果有一个 createCriteria 解决方案也很好。谢谢。

4

1 回答 1

2

我从未尝试过,但Hibernate 文档说,“where”子句支持 coalesce()。如果它在“选择”子句中也可用,您可以选择合并日期,然后按它排序,因为文档还指出

“查询返回的列表可以按返回的类或组件的任何属性排序”

所以,也许是这样的:

 select h.prop1, h.prop2, coalesce(h.fixDate, h.downDate, h.createdDate) as orderDate from history h where ..... order by orderDate
于 2012-09-24T23:05:17.970 回答