您的位置:首页 > 产品设计 > UI/UE

Incorrect datetime value: '' for column 'log_time' at row 1

2014-11-01 21:22 295 查看
在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));

不知道简单的解决方法是什么。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐