我有一个JPQL查询
@Query("SELECT e FROM Entry e WHERE :chosenDate BETWEEN e.periodFrom AND e.periodTo")
List<Entry> findByChosenDate(LocalDate chosenDate);
有一个问题,当未设置属性“ periodFrom”或“ periodTo”之一时,将不会选择该条目。我希望查询还包括带有一个或两个NULL值的整数。
我希望查询在其他三种情况下选择条目:
当“ periodFrom”为空且“ periodTo”为空时,应找到该条目。
当“ periodFrom”为空并且“ periodTo”> =:chosenDate时,应找到该条目。
当“ periodFrom” <=:chosenDate和“ periodTo”为空时,应找到该条目。
有没有比这样更简单的查询方式了?
@Query("SELECT e FROM Entry e WHERE (:chosenDate BETWEEN e.periodFrom AND e.periodTo)
OR (e.periodFrom IS NULL AND e.periodTo IS NULL )
OR ( e.periodFrom <= :chosenDate AND e.periodTo IS NULL)
OR (e.periodFrom IS NULL AND e.periodTo >= :chosenDate)")
List<Entry> findByChosenDate(LocalDate chosenDate);
答案 0 :(得分:8)
我不知道您是否觉得更好,但是这样的话会更短:
SELECT e FROM Entry e WHERE (:chosenDate BETWEEN COALESCE(e.periodFrom, 0000-01-01) AND COALESCE(e.periodTo, 9999-12-31)