2012-09-18 21 views
5

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óci false ponieważ 2011 < 2012 ale 10 !< 09

Jeśli używam OR zamiast AND, to jeszcze źle:

  • 2013-01 LTE 2012-05 powinien powrócić false ale powróci true ponieważ 2013 !< 2012 ale 01 < 05

Tak, jak powinienem przetworzyć? Proszę, potrzebuję go dla JAVA i HQL.

Odpowiedz

6

To powinno zadziałać.

select item from Item item 
where year(item.d1) < year(:d2) or 
    (year(item.d1) = year(:d2) 
     and month(item.d1) <= month(:d2)) 

samo dla Java:

y1 < y2 || (y1 == y2 && m1 <= m2) 

Można zachować drugi czek jako y1 <= y2 ale byłoby to trochę zbędne.

+1

Mężczyzna, oczywiście, masz rację! Dzięki ';)' – sp00m