GRAILS:HQL - 按IF排序(ISNULL)

时间:2012-09-24 21:50:38

标签: grails hql gorm

我想知道如何格式化这个查询。我有一个有三个日期的表,其中一些可以为空。这三个字段是createdDate,downDate和fixDate。我需要根据日期查询并获取最新条目。例如,如果fixDate不为null,那么它由fixDate命令,如果它为null,那么我需要通过downDate命令。如果downDate为null,那么我按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解决方案也没关系。感谢。

1 个答案:

答案 0 :(得分:2)

我从未尝试过,但Hibernate documentation表示'where'子句支持coalesce()。如果它也在'select'子句中可用,您可以选择合并日期,然后按顺序排序,因为文档还说明了

  

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

所以,或许类似于:

 select h.prop1, h.prop2, coalesce(h.fixDate, h.downDate, h.createdDate) as orderDate from history h where ..... order by orderDate