hibernate中OID代表什么

原文链接http://zhhll.icu/2020/12/12/%E6%A1%86%E6%9E%B6/hibernate/OID%E6%98%A0%E5%B0%84%E5%AF%B9%E8%B1%A1%E6%A0%87%E8%AF%86%E7%AC%A6/

OID映射对象标识符

OID存在的意义

关系型数据库通过主键来区分同一张表的不同数据,java语言使用内存地址来区分同一类的不同对象,hibernate则使用OID来同一两者之间的矛盾,在运行时,hibernate通过OID来维持java对象和数据库表中记录的对应关系。

OID的配置

在hibernate映射文件中配置,使用<id>元素来设置对象标识符

<id name="id" type="java.lang.Integer">
  <column name="id"/>
  <generator class="increment"/>
</id>

<generator>子元素来设定标识符生成器,标识符生成器的接口为org.hibernate.id.IdentifierGenerator接口,以及提供了几种内置的实现

  • increment Hibernate以递增的方式赋值 先查该表的id最大值,再加一 存在并发问题
  • identity 由底层数据库生成,需要把主键设置为自增的(需要底层数据库支持自增 如DB2、Mysql、SQL SERVER)
  • sequence 底层数据库序列生成(需要底层数据库支持序列 如Oracle、DB2、PostgreSQL)
  • hilo 由hibernate按照一种high/low算法生成,hibernate把特定表的字段最为high值。默认为hibernate_unique_key表的next_hi字段 注意:hilo的方式需要在单独的事务中处理,不使用session对象的当前数据库连接和事务,而是单独的在一个新的数据库连接中创建新的事务,与spring结合时以及配置数据源时注意不可使用该方式生成
  • native 根据底层数据库对自动生成主键的支持能力,来选择identity,sequence或hilo生成器
  • uuid.hex hibernate采用128位的UUID生成
  • assigned 由java程序负责生成
  • select 由数据库中的触发器来生成
  • foreign 用另一个关联对象的标识符来作为当前对象的标识符,主要用于一对一关联关系

复合主键的配置

复合主键的配置使用<composite-id>

<composite-id>
  <key-property name="name" column="name" type="java.lang.String"/>
  <key-property name="companyId" column="company_id" type="java.lang.Long"/>
</composite-id>

注意在使用复合主键时,需要定义version版本控制属性,用来区分临时对象和游离对象,判断是保存还是更新

<!-- 表示当对象的version对象为null时为游离对象,还没有被保存过 -->
<version name="version" column="version" unsaved-value="null"/>

由于本身的博客百度没有收录,博客地址http://zhhll.icu

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,706评论 4 366
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,002评论 1 301
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 110,462评论 0 250
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,375评论 0 216
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,763评论 3 294
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,849评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,033评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,768评论 0 204
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,490评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,734评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,204评论 1 264
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,566评论 3 260
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,227评论 3 241
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,137评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,934评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,926评论 2 283
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,774评论 2 274

推荐阅读更多精彩内容