创星网络[分享知识 传递快乐]

标题: 空日期类型的mysql + java解决方法 [打印本页]

作者: luinstein    时间: 2012-12-12 22:07
标题: 空日期类型的mysql + java解决方法
在使用MySql 时, 数据库中的字段类型是timestamp的,默认为0000-00-00, 会发生异常:java.sql.SQLException:   Value   '0000-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字段默认值查询时的处理方式;默认是抛出异常,

对于值为0000-00-00   00:00:00(默认值)的纪录,如下两种配置,会返回不同的结果:

zeroDateTimeBehavior=round   0001-01-01   00:00:00.0

zeroDateTimeBehavior=convertToNull   null  


我的解决方法:
database.url=jdbc:mysql://1.1.1.1:3306/的b?useOldUTF8Behavior=true&useUnicode=true&characterEncoding=UTF8&zeroDateTimeBehavior=convertToNull

形如:
jdbc.connection.cxweb.url=jdbc:mysql://127.0.0.1:3306/cxweb?useUnicode=true&autoReconnect=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull





欢迎光临 创星网络[分享知识 传递快乐] (http://bbs.cxweb.com.cn/) Powered by Discuz! X3