Je me trompe de nombre de jours lorsque je trouve la différence entre deux dates sql. Le tableau suivant montre la méthode:Se tromper de nombre de jours en utilisant JodaTime
public Vector getAvailRoom(String RoomID)
{
formatter = new SimpleDateFormat("dd-MM-yyyy HH:mm:ss");
Date dateA = null;
Date dateD = null;
Vector vect = new Vector();
try
{
psmt=con.prepareStatement("select * from Booking where RmID="+RoomID);
rs=psmt.executeQuery();
while(rs.next())
{
AvailDetails2 avaDet = new AvailDetails2();
avaDet.BookArrivalDate = rs.getString("BookArrivalDate");
avaDet.BookDepartureDate = rs.getString("BookDepartureDate");
System.out.println(""+avaDet.BookArrivalDate);
System.out.println(""+avaDet.BookDepartureDate);
try
{
dateA = (Date) formatter.parse(avaDet.BookArrivalDate);
dateD = (Date) formatter.parse(avaDet.BookDepartureDate);
DateTime datetimeA = new DateTime(dateA);
DateTime datetimeD = new DateTime(dateD);
diffDays = Days.daysBetween(datetimeA.toLocalDate(), datetimeD.toLocalDate()).getDays();
System.out.println(""+diffDays);
avaDet.BookDiffDays = Integer.toString(diffDays);
}
catch (Exception egetAvailRoom)
{
egetAvailRoom.printStackTrace();
}
vect.add(avaDet);
}
}
catch (Exception e3)
{
}
return vect;
}//end getAvailRoom
On suppose
BookArrivalDate
est 2013-10-01 00:00:00
et
BookDepartureDate
est 2013-10-14 00:00:00
je reçois 4748 comme la différence.
Veuillez formater votre code en utilisant des espaces au lieu d'onglets - c'est très difficile à lire pour le moment. –
Aussi, s'il vous plaît montrer le problème dans un programme court mais * complet *. Il ne devrait pas être nécessaire d'impliquer une base de données ici - vous devriez être capable de fournir un programme que nous pouvons copier, coller et lancer pour voir le problème. –