Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Das in der Datenbank gespeicherte Datum ist nicht gleich dem abgerufenen Datum

Aus der MySQL-Dokumentation :

Beachten Sie, dass Sie zum Vergleichen von Datumsangaben sowieso nicht equals verwenden sollten, da die verschiedenen Date-Unterklassen fehlerhafte Implementierungen haben, die Probleme wie a.equals(b) && !b.equals(a) verursachen :

java.util.Date d1 = java.sql.Date.valueOf("2012-01-01");
java.util.Date d2 = new java.util.Date(d1.getTime());
java.util.Date d3 = new java.sql.Timestamp(d1.getTime());

System.out.println(d1.equals(d2)); // true
System.out.println(d2.equals(d1)); // true
System.out.println(d1.equals(d3)); // true
System.out.println(d3.equals(d1)); // false
System.out.println(d2.equals(d3)); // true
System.out.println(d3.equals(d2)); // false