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 restituiretrue
ma restituiràfalse
perché2011 < 2012
ma10 !< 09
Se uso un OR
invece di un AND
, è comunque sbagliato:
2013-01 LTE 2012-05
dovrebbe restituirefalse
ma torneràtrue
perché2013 !< 2012
ma01 < 05
Quindi, come dovrei elaborare? Per favore, ne ho bisogno per JAVA e HQL.
Uomo, certo, hai ragione! Grazie ';)' – sp00m