java.sql.SQLException: Value'0000-00-00'异常解决
2015-09-12 22:02
615 查看
在使用MySql 时, 数据库中的字段类型是timestamp的,默认为0000-00-00, 会发生异常:java.sql.SQLException: Value '0000-00-00 ' can not be represented as java.sql.Timestamp
“0000-00-00 00:00:00”在mysql中是作为一个特殊值存在的
但 java.sql.Date 将其视为 不合法的值 格式不正确因此产生异常
异常解决办法:
给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
接收方式:
如果类型被定义为java.sql.Timestamp 这种类型的话 ResultSet 接收类型必须是Timestamp 这种类型不能使用java.sql.Date 类型。
接收到这种类型之后可以进行类型的转化 new Date(timestamp.getTime());
“0000-00-00 00:00:00”在mysql中是作为一个特殊值存在的
但 java.sql.Date 将其视为 不合法的值 格式不正确因此产生异常
异常解决办法:
给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
接收方式:
如果类型被定义为java.sql.Timestamp 这种类型的话 ResultSet 接收类型必须是Timestamp 这种类型不能使用java.sql.Date 类型。
接收到这种类型之后可以进行类型的转化 new Date(timestamp.getTime());
相关文章推荐
- UI设计 视图控制器
- EasyUI queryParams属性 在请求远程数据同时给action方法传参
- easyui的combobox控件进一步优化
- UI课程10 UITableView的编辑
- UIScrollView添加自动布局
- IOS上 关于状态栏的相关设置(UIStatusBar)
- 1101. Quick Sort (25)
- [iOS]给UILabel赋HTML数据。
- UISearchBar基本设置 和 代理方法
- 用NGUI显示图片鼠标点击的地方出现在屏幕上
- Java请求参数类QueryParameter
- EasyUI学习笔记_1
- 关于UI线程的阻塞问题以及处理方式
- Dynamic Programming实战一:Longest Increasing Subsequence算法分析及C代码实现
- POJ 1776 - Task Sequences(哈密顿图)
- UIStatusBarStyle的类型改变
- UISegmentedControl 开发笔记
- Android Dialog中的Builder设计模式
- POJ - 1986 Distance Queries(LCA离线)
- Codeforces Round #316 Tree Requests