您的位置:首页 > 其它

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)后还是等待,没有事件通知功能)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: