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