码迷,mamicode.com
首页 > 数据库 > 详细

Mysql 时间格式默认空串 '0000-00-00 00:00:00' select抛出异常的解决方法

时间:2016-05-30 21:28:31      阅读:272      评论:0      收藏:0      [点我收藏+]

标签:

Mysql 时间格式默认插入值为空时,会以‘0000-00-00 00:00:00‘填充,这时如果select时会抛出SQLExecption如下:

java.sql.SQLException: Value ‘0000-00-00 00:00:00‘ can not be represented as java.sql.Timestamp

 

解决方法如下:

方法一:jdbc的url加zeroDateTimeBehavior参数: 

datasource.url=jdbc:mysql://localhost:3306/testdb?useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&transformedBitIsBoolean=true 

zeroDateTimeBehavior=round是为了指定MySql中的DateTime字段默认值查询时的处理方式;默认是抛出异常,

(摘自:http://www.blogjava.net/hilor/articles/164814.html)

 

方法二:select 语句中做如下处理:

SELECT ID, IF(createDate=‘0000-00-00 00:00:00‘,‘null‘,createDate)createDate FROM T_DateTest;

这里将createDate格式转换为”null“展示,不再抛出SQLException。

 

Mysql 时间格式默认空串 '0000-00-00 00:00:00' select抛出异常的解决方法

标签:

原文地址:http://www.cnblogs.com/hunterCecil/p/5543732.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!