Hibernate + Spring + MySql: Cannot convert value '0000-00-00 00:00:00' from column X to TIMESTAMP

When I was trying to load an Hibernate object, I received the following error:

nested exception is java.sql.SQLException: Cannot convert value '0000-00-00' from column 4 to TIMESTAMP.
at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQL

This exception means that the column "X" has an invalid date "0000-00-00 00:00:00"
According to http://bugs.mysql.com/bug.php?id=13030 "Datetimes with all-zero components ('0000-00-00 ...') - These values can not represented reliably in Java. Connector/J 3.0.x always converted them to NULL when being read from a ResultSet.


When working with MySQL over JDBC and the driver encounters a zero DATE, TIME, or DATETIME value (that is, e.g, ‚0000–00–00‘ for DATE), this exception is thrown.

This can be handled by adding the JDBC Parameter: zeroDateTimeBehavior=convertToNull to your JDBC connection.

url=jdbc:mysql://localhost/test?connectTimeout=60000&autoReconnect=true&zeroDateTimeBehavior=convertToNull

Comments

Popular posts from this blog

Hibernate: a different object with the same identifier value was already associated with the session

BeanDefinitionStoreException: Failed to parse configuration class: Could not find class [javax.jms.ConnectionFactory]

org.hibernate.HibernateException: Unable to instantiate default tuplizer [org.hibernate.tuple.entity.PojoEntityTuplizer]