我想知道如何格式化这个查询。我有一个有三个日期的表,其中一些可以为空。这三个字段是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解决方案也没关系。感谢。
答案 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