热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

Hibernate的相关问题

1.Hibernate数据库中明明有,但是Get总返回nullOracle的CHAR(15)类型,如果字符串ID不足15个字符,则会自动用空格补齐。虽然在SqlPlus工具查询的时候,不需要补齐空格。但是在Hibernate查询的时候需要补齐的。这也是为何Hibernateget查询的时候,数据

1. Hibernate数据库中明明有,但是Get总返回null Oracle的CHAR(15)类型,如果字符串ID不足15个字符,则会自动用空格补齐。 虽然在Sql Plus工具查询的时候,不需要补齐空格。 但是在Hibernate查询的时候需要补齐的。 这也是为何Hibernate get查询的时候,数据

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)后还是等待,没有事件通知功能)


推荐阅读
author-avatar
我心飞翔
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有