Hibernate继续进阶——映射关系

映射文件

映射文件的配置
  • name: 属性的名字。这个类的属性的名字,而且是与之关联的属性的名字
  • class (可选 - 默认是通过反射得到的属性类型):被关联的类的名字。
  • cascade(级联) (可选):表明操作是否从父对象级联到被关联的对象。
  • constrained(约束) (可选):表明该类对应的表对应的数据库表,和被关联的对象所对应的数据库表之间,通过一个外键引用对主键进行约束。
    这个选项影响save()和delete()在级联执行时的先后顺序
    以及决定该关联能否被委托(也在schema export tool中被使用).
  • fetch (可选 - 默认设置为选择): 在外连接抓取或者序列选择抓取选择其一.
  • property-ref (可选):指定关联类的属性名,这个属性将会和本类的主键相对应。
    如果没有指定,会使用对方关联类的主键。
  • access (可选 - 默认是 property): Hibernate用来访问属性的策略。
  • formula (可选):绝大多数一对一的关联都指向其实体的主键。
    在一些少见的情况中, 你可能会指向其他的一个或多个字段,或者是一个表达式,
    这些情况下,你可以用一个SQL公式来表示。
    (可以在org.hibernate.test.onetooneformula找到例子)
  • lazy (可选 - 默认为 proxy): 默认情况下,单点关联是经过代理的。lazy="no-proxy"指定此属性应该在实例变量第一次被访问时应该延迟抓取(fetche lazily)(需要运行时字节码的增强)。 lazy="false"指定此关联总是被预先抓取。注意,如果constrained="false", 不可能使用代理,Hibernate会采取预先抓取!
  • entity-name (可选): 被关联的类的实体名。
一对一

一个人对应一张身份证,一张身份证对应一个人

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.zts.day05.one2one">
<class name="Person" table="tbl_person">
    <id name="id" column="id">
        <generator class="increment" />
    </id>
    <property name="name" />
    <!--在主方配置一对一,property-ref="person"这个属性意味着主方的主键配置从方的外键,默认是主方的主键配置从方的主键 -->
    <one-to-one name="card" class="Card" property-ref="person" />
</class>
</hibernate-mapping>
  • <one-to-one name="card" class="Card" property-ref="person" />
  • 在card.hbm.xml中配置
    <one-to-one name="person" class="Person" constrained="true"></one-to-one>
同时由于一对一是特殊的多对一中多为唯一的特例所以针对关联属性我们也可以这样写:

<many-to-one name="person" class="Person" unique="true" column="p_id"/>

多对一

一个顾客对应多个订单,多个订单对应一个顾客

顾客
 <!--关联映射    false是延迟加载关联映射 ,默认为true-->
    <set name="orders" lazy="true"  cascade="all">
    <key column="c_id"></key>
    <one-to-many class="Order" />
    </set>
订单
 <!--关联映射 -->
    <many-to-one name="customer" class="Customer" column="c_id"></many-to-one> 
多对多

一个学生可以选多门课程,一名课程可以有多名学生选择

#######学生

<set name="courses" table="tbl_student_course">
<key column="s_id"></key>
<many-to-many class="Course" column="c_id"></many-to-many>
</set>
#######课程
<set name="students" table="tbl_student_course">
<key column="c_id"></key>
<many-to-many class="Student" column="s_id"></many-to-many>
</set>
我们必须在 set标签这里加入一个table属性,这样就会默认帮我们加载这个表。不然系统会自动帮我创建两个表。

两个一对多

多对多我们可以看成是tbl_student对tbl_student_course(桥表)的一对多和tbl_course对tbl_student_course(桥表)的一对多。

#######学生
<set name="stucous">
<key column="s_id"></key>
<one-to-many class="Stucou" />
</set>
#######课程
<set name="stucous">
<key column="c_id"></key>
<one-to-many class="Stucou"/>
#######学生——课程

<many-to-one name="student" class="Student" column="s_id"/>
<many-to-one name="course" class="Course" column="c_id"/>
这样写的好处是:我们可以给桥表增加属性比如:grade(分数),comment(评论)等等。

<set cascade="all",inverse="false"/>两个属性详解

级联操作

在映射文件中的关联元素中都有一个cascade属性,用来指定如果操纵与当前对象关联的其他对象。eg: cascade="all"

  • none: 在保存,更新,删除当前对象的时候忽略其他关联的对象。是cascade的默认值
  • save-update: 当通过Session的save(),update(),saveOrUpdate()方法来保存或者更新当前对象的时候级联保存所有关联的临时对象,级联更新所有关联的游离对象。
  • delete: 当通过Session的delete()方法删除当前对象的时候级联删除所有关联的对象。
  • all:包含save-update和delete的行为。
  • delete-orphan:删除所有和当前对象解除关联关系的对象。(只能在set中配置
  • all-delete-orphan: 包含all和delete-orphan的行为

inverse:负责控制关系

默认inverse="false" 只能显示在<set>放进行设置

  1. inverse真正的作用是指定由哪一方来维护之间的关联关系,当一方指定inverse="false"那么这一方就有责任负责之间的关联关系。.需要将其中的一方inverse="true"

  2. 在一对多关系中,如果使用默认的inverse,那么意味着双方都可以维护关联关系,也就说在代码中可以仅仅用主方来维护从方,也可以用从方来维护主方,如果双向维护将会有一次重复更新。

  3. 在多对多关系中,如果用双方的外键来作为桥表的主键,只能一方来维护关联关系,意味着必须要将其中的一方设置为inverse="true",不然将会造成主键冲突的异常。

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

推荐阅读更多精彩内容