Muszę być w stanie porównać dwie daty, tylko w oparciu o rok i miesiąc (tj. Bez zwracania uwagi na dzień), a także w JAVA i HQL.Porównaj dwie daty w oparciu o rok, nie biorąc pod uwagę dnia
Załóżmy, że muszę sprawdzić, czy d1
jest mniejsze lub równe d2
. Oto, co starałem:
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)
Algorytm jest taki sam w obu kawałków kodu powyżej, ale to jest złe:
2011-10 LTE 2012-09
powinien zwrócićtrue
, ale zwrócifalse
ponieważ2011 < 2012
ale10 !< 09
Jeśli używam OR
zamiast AND
, to jeszcze źle:
2013-01 LTE 2012-05
powinien powrócićfalse
ale powrócitrue
ponieważ2013 !< 2012
ale01 < 05
Tak, jak powinienem przetworzyć? Proszę, potrzebuję go dla JAVA i HQL.
Mężczyzna, oczywiście, masz rację! Dzięki ';)' – sp00m