Hibernate的相关问题
2014-01-15 16:55
351 查看
1. Hibernate数据库中明明有,但是Get总返回null
Oracle的CHAR(15)类型,如果字符串ID不足15个字符,则会自动用空格补齐。
虽然在Sql Plus工具查询的时候,不需要补齐空格。
但是在Hibernate查询的时候需要补齐的。
这也是为何Hibernate get查询的时候,数据库中明明有,却返回null的原因之一
2.Hibernate在插入记录的时候,commit等待、假死、不执行下一步的根本原因
Hibernate在插入记录的时候,如果ID(主键值)重叠,则会等待,奇怪。根本原因在于
SQLPlus或者Hibernate操作该数据表没有提交导致。当然如果已经提交了,ORACLE不要求
Hibernate等待的时候,Hibernate本身会抛出异常。
比如SQL PLUS 用delete from school where id=1;但执行完后没有commit
然后Hibernate 要插入id=1的记录,那么ORACLE将让Hibernate等待,一面出现了错误的逻辑。
(感觉ORACLE或者Hibernate也没有设计得多好,因为在Hibernate因为SQL PLUS没有提交时而
等待,但是SQL PLUS 提交(commit)后还是等待,没有事件通知功能)
Oracle的CHAR(15)类型,如果字符串ID不足15个字符,则会自动用空格补齐。
虽然在Sql Plus工具查询的时候,不需要补齐空格。
但是在Hibernate查询的时候需要补齐的。
这也是为何Hibernate get查询的时候,数据库中明明有,却返回null的原因之一
2.Hibernate在插入记录的时候,commit等待、假死、不执行下一步的根本原因
Hibernate在插入记录的时候,如果ID(主键值)重叠,则会等待,奇怪。根本原因在于
SQLPlus或者Hibernate操作该数据表没有提交导致。当然如果已经提交了,ORACLE不要求
Hibernate等待的时候,Hibernate本身会抛出异常。
比如SQL PLUS 用delete from school where id=1;但执行完后没有commit
然后Hibernate 要插入id=1的记录,那么ORACLE将让Hibernate等待,一面出现了错误的逻辑。
(感觉ORACLE或者Hibernate也没有设计得多好,因为在Hibernate因为SQL PLUS没有提交时而
等待,但是SQL PLUS 提交(commit)后还是等待,没有事件通知功能)
相关文章推荐
- 【树形DP】 HDU 4008 Parent and son
- PVRTC compression
- 基于OPenStack平台的C++ API 设计
- 让程序只运行一个实例的四种方法
- Ajax之工厂模式封装XMLHttpRequest
- PreparedStatement的用法
- mysql建表常用sql语句分享
- 开源中国 Maven 库使用帮助
- 【LeetCode】N-Queens && 【九度】题目1140:八皇后
- 玩android 遇到的问题-2014年1月15日
- 拆掉你思维里的墙
- 从devstack开始 学习openstack
- 使用 Mcafee 镜像任务 建立升级服务器
- java 八字计算
- -1
- 单纯gdb调试android的so断点
- Java冒泡排序
- Android.mk中的变量的使用介绍(二)
- 英语学习方法
- CGContextAddArcToPoint看图说话