5
我需要能夠比較兩個日期,僅基於年份和月份(即不考慮當天),以及在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
但將返回true
因爲2013 !< 2012
但01 < 05
那麼,如何我應該處理?請,我需要它的JAVA和HQL。
男人,當然,你是對的!謝謝';)' – sp00m