我需要能够比较两个日期,仅基于年份和月份(即没有注意到当天),以及JAVA和HQL中的日期.
假设我需要检查d1是否小于或等于d2.这是我尝试过的:
JAVA
calendar.setTime(d1);
int y1 = calendar.get(Calendar.YEAR);
int m1 = calendar.get(Calendar.MONTH);
calendar.setTime(d2);
int y2 = calendar.get(Calendar.YEAR);
int m2 = calendar.get(Calendar.MONTH);
return y1 <= y2 && m1 <= m2;
HQL
select item from Item item
where year(item.d1) <= year(:d2)
and month(item.d1) <= month(:d2)
上面两段代码中的算法都是一样的,但是错了:
> 2011-10 LTE 2012-09应该返回true但是将返回false,因为2011< 2012年但10岁!< 09
如果我使用OR而不是AND,它仍然是错误的:
> 2013-01 LTE 2012-05应返回false,但因为2013年将返回true!< 2012年但是01< 05
那么,我应该如何处理?拜托,我需要它用于JAVA和HQL.