在java里面操作MySQL数据库时,出现了如下的错误:Incorrect datetime value: '' for column 'log_time' at row 1。我的数据库里面有个datetime的数据类型,用的是如下的代码
ps2.setTimestamp(2, new java.sql.Timestamp(new java.util.Date().getTime()));
在网上说更新mysql-connector-java-bin.jar,试了不管用。
然后看到一篇文章参见http://www.cnblogs.com/lv_yantao/archive/2011/11/13/2246950.html,修改mysql的配置文件my.ini
my.ini中查找sql-mode,
默认为sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION",
将其修改为sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION",重启mysql后即可
试了一下,是可以运行了,关键时,写入数据库里的datetime都变成了00:00:00:00:00:00。无奈之下只好用最笨的方法,先获取util.date时间,再转换成string,然后再转换成sql.date,如下:
java.util.Date da=new java.util.Date();//取当前时间
SimpleDateFormat sf = new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //转换时间格式
String formatDa = sf.format(da);//
ps2.setTimestamp(2, Timestamp.valueOf(formatDa));
不知道简单的解决方法是什么。