2012-09-18 8 views
5

Devo essere in grado di confrontare due date, solo in base all'anno e al mese (cioè senza prendere in considerazione il giorno), e quello in JAVA e HQL.Confronta due date in base all'anno-mese, senza preavviso del giorno

Diciamo che è necessario verificare se d1 è inferiore o uguale a d2. Ecco quello che ho provato:

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) 

L'algoritmo è lo stesso in entrambi i pezzi di codice di cui sopra, ma è sbagliato:

  • 2011-10 LTE 2012-09 dovrebbe restituire true ma restituirà false perché 2011 < 2012 ma 10 !< 09

Se uso un OR invece di un AND, è comunque sbagliato:

  • 2013-01 LTE 2012-05 dovrebbe restituire false ma tornerà true perché 2013 !< 2012 ma 01 < 05

Quindi, come dovrei elaborare? Per favore, ne ho bisogno per JAVA e HQL.

risposta

6

Questo dovrebbe funzionare.

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

Lo stesso per Java:

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

si potrebbe tenere secondo controllo come y1 <= y2 ma sarebbe un po 'ridondante.

+1

Uomo, certo, hai ragione! Grazie ';)' – sp00m