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

在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));

不知道简单的解决方法是什么。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值