Mysql5.6出现时间问题Incorrect datetime value: '' for column 'createtime'

分类:数据库| 发布:佚名| 查看: | 发表时间:2014/7/1

今天部署服务器项目运行,当遇见有时间数据对象的插入和更新操作的时候,就报错,如下:

Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: 
Incorrect datetime value: '' for column 'createtime' at row 1 at
com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2868) at
com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1573) at
com.mysql.jdbc.ServerPreparedStatement.serverExecute(ServerPreparedStatement.java:1160) at
com.mysql.jdbc.ServerPreparedStatement.executeInternal(ServerPreparedStatement.java:685) at
com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1400) at
com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1314) at
com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1299) at
org.apache.commons.dbcp.DelegatingPreparedStatement.executeUpdate(DelegatingPreparedStatement.java:105) at
org.apache.commons.dbcp.DelegatingPreparedStatement.executeUpdate(DelegatingPreparedStatement.java:105) at
org.hibernate.id.IdentityGenerator$GetGeneratedKeysDelegate.executeAndExtract(IdentityGenerator.java:94) at
org.hibernate.id.insert.AbstractReturningDelegate.performInsert(AbstractReturningDelegate.java:57) ... 109 more

因为在测试服务器上该项目是正常的,所以比较纳闷,项目是一样的都是hibernate3.6,那就是JDK版本,MySQL版本,还有Tomcat版本不一样导致。最终排除其它,锁定在MySQL版本问题上,我在测试上用的是5.1版本,服务器上使用的是最新的5.6版本;看到网上说5.6对时间类型做了调整,于是果断换成5.5的Mysql64位。测试,通过,正常。

所以,遇见该问题解决方法,目前是换数据库版本,因为是5.6版本比较新

解决方案:

更新下最新版本的mysql-connector包就可以了。

365据说看到好文章不转的人,服务器容易宕机
原创文章如转载,请注明:转载自郑州网建-前端开发 http://camnpr.com/
本文链接:http://camnpr.com/database/1289.html