概念:
1. 单向关联:仅仅在A类中定义B类的b属性,或仅仅在B类中定义A类的a属性,是单方面的。
2. 多向关联:既在A类中定义B类的b属性,又在B类中定义A类的a属性,是两方面的。
3. 具体关系分为:单向多对一、单向一对多、双向多对一、双向一对多、双向多对多
举例定义:A类有a属性,B类有b属性。
一.单向多对一: 只需从N的一端访问到1的一端
<many-to-one>元素中的属性:
1> name:设定待映射的持久化类的名称
2> column:设定持久化类的属性对应的表的外键
二.单向一对多: 只需从1的一端访问到N的一端
举例映射:
<set>元素来映射持久化类的set类型的属性
name:设定待映射持久化类的属性名
cascade:设定级联操作的程度
<key>子元素:设定与所关联的持久化类对应的表的外键
column:指定关联表的外键名
<one-to-many>子元素:设定所关联的持久化类(集合中存放的对象)
class:指定关联的持久化类的类名
三.双向一对多: 1的一端访问到N的一端,N的一端也可访问到1的一端
1. 持久化类:双方都有相应的属性
映射文件:双方都有相应的映射
2. 父子关系:指父方控制子方的持久化生命周期,子方对象必须和一个父方对象关联
四.双向多对一: N的一端访问到1的一端,1的一端也可访问到N的一端
五.双向多对多
1> 双向N-N关联必须使用中间表,该表是联合主键。
2> 双向N-N关联需要两端都使用集合属性
3> 属性集合应使用<key>子元素用来映射文件列,应使用<many-to-many>子元素来关联实体类
4> 双向N-N关联的两端都需指定连接表的表名(name)以及外键列的列名(cloumn);
两端的<set>集合元素的table属性的值必须指定且相同。
5> <set>元素中的<key>和<many-to-many>子元素都必须指定column属性
6> <key>和<many-to-many>分别指定本持久化类和关联类在连接表中的外键列名
7> 两端的<key>和<many-to-many>的column属性交叉相同。意思是:一端的<set>元素中<key>子元素的column值为a,<many-to-many>子元素的column值为b;则另一端的<set>元素中<key>子元素的column值为b,<many-to-many>子元素的column值为a。
8> 双向N-N关联中必须把其中一端设置"inverse=true"属性,否则造成主键冲突。
六.单向多对多: 去掉双项多对多关联中的任意一方
级联:当主控方执行操作时,关联对象(被动方)是否同步执行同一操作。
级联风格与session中相对应的方法
persist persist()
merge merge()
save-update save()、update()、saveOrUpdate()
delete delete()
lock lock()
refresh refresh()
evict evict()
replicate replicate()
指定级联风格:
<one-to-one name="user" cascade="persist" />
级联风格是可组合的:
<one-to-one name="user" cascade="persist,delete" />
也可以使用cascade="all"指定全部操作都顺着关联关系级联。
默认值是cascade="none",即任何操作都不会级联
属性二:inverse
1> 在Hibernate中通过对inverse属性的值决定是由双向关联的哪一方来维护表与表之间的关系
inverse=false表示主动方,inverse=true表示被动方。
2> 如果没有设置inverse=true时,父子两边都维护父子关系。
3> 在1-N关系中,将N方设为主控方将有助于性能改善(提示:如果要国家元首记住全国人民的名字,不现实;而让全国人民记住国家元首的名字,就轻而易举。意在让多数记住少数)。
4> 在1-N关系中,将1方设为主控方会额外多出update语句。插入数据时无法同时插入外键列,因而无法为外键列添加非空约束。
5> 在映射一对多的双向关联关系时,将one方设置为inverse=true,以提高性能。
6> 只有集合标记(set/list/map/array/bag)才有inverse属性。
属性三:order-by
1> <set>元素包含order-by属性,设置该属性后,Hibernate通过select语句到数据库中检索集合对象时,利用order-by子句进行排序(注:指定的是SQL语句的OrderBy子句,要写列名)。
2> order-by属性中可以加入SQL函数。
1. 单向关联:仅仅在A类中定义B类的b属性,或仅仅在B类中定义A类的a属性,是单方面的。
2. 多向关联:既在A类中定义B类的b属性,又在B类中定义A类的a属性,是两方面的。
3. 具体关系分为:单向多对一、单向一对多、双向多对一、双向一对多、双向多对多
举例定义:A类有a属性,B类有b属性。
一.单向多对一: 只需从N的一端访问到1的一端
例:在A类中定义B类的b属性,而B类无需定义A类的任何属性。
在A类数据库表中的b_id参照B表的主键
<many-to-one>元素中的属性:
1> name:设定待映射的持久化类的名称
2> column:设定持久化类的属性对应的表的外键
3> class:设定持久化类的属性的类型
4> not-null:是否允许为空
二.单向一对多: 只需从1的一端访问到N的一端
举例映射:
<set>元素来映射持久化类的set类型的属性
name:设定待映射持久化类的属性名
cascade:设定级联操作的程度
<key>子元素:设定与所关联的持久化类对应的表的外键
column:指定关联表的外键名
<one-to-many>子元素:设定所关联的持久化类(集合中存放的对象)
class:指定关联的持久化类的类名
三.双向一对多: 1的一端访问到N的一端,N的一端也可访问到1的一端
1. 持久化类:双方都有相应的属性
映射文件:双方都有相应的映射
2. 父子关系:指父方控制子方的持久化生命周期,子方对象必须和一个父方对象关联
四.双向多对一: N的一端访问到1的一端,1的一端也可访问到N的一端
五.双向多对多
1> 双向N-N关联必须使用中间表,该表是联合主键。
2> 双向N-N关联需要两端都使用集合属性
3> 属性集合应使用<key>子元素用来映射文件列,应使用<many-to-many>子元素来关联实体类
4> 双向N-N关联的两端都需指定连接表的表名(name)以及外键列的列名(cloumn);
两端的<set>集合元素的table属性的值必须指定且相同。
5> <set>元素中的<key>和<many-to-many>子元素都必须指定column属性
6> <key>和<many-to-many>分别指定本持久化类和关联类在连接表中的外键列名
7> 两端的<key>和<many-to-many>的column属性交叉相同。意思是:一端的<set>元素中<key>子元素的column值为a,<many-to-many>子元素的column值为b;则另一端的<set>元素中<key>子元素的column值为b,<many-to-many>子元素的column值为a。
8> 双向N-N关联中必须把其中一端设置"inverse=true"属性,否则造成主键冲突。
六.单向多对多: 去掉双项多对多关联中的任意一方
属性一:级联
级联:当主控方执行操作时,关联对象(被动方)是否同步执行同一操作。
级联风格与session中相对应的方法
persist persist()
merge merge()
save-update save()、update()、saveOrUpdate()
delete delete()
lock lock()
refresh refresh()
evict evict()
replicate replicate()
指定级联风格:
<one-to-one name="user" cascade="persist" />
级联风格是可组合的:
<one-to-one name="user" cascade="persist,delete" />
也可以使用cascade="all"指定全部操作都顺着关联关系级联。
默认值是cascade="none",即任何操作都不会级联
属性二:inverse
1> 在Hibernate中通过对inverse属性的值决定是由双向关联的哪一方来维护表与表之间的关系
inverse=false表示主动方,inverse=true表示被动方。
2> 如果没有设置inverse=true时,父子两边都维护父子关系。
3> 在1-N关系中,将N方设为主控方将有助于性能改善(提示:如果要国家元首记住全国人民的名字,不现实;而让全国人民记住国家元首的名字,就轻而易举。意在让多数记住少数)。
4> 在1-N关系中,将1方设为主控方会额外多出update语句。插入数据时无法同时插入外键列,因而无法为外键列添加非空约束。
5> 在映射一对多的双向关联关系时,将one方设置为inverse=true,以提高性能。
6> 只有集合标记(set/list/map/array/bag)才有inverse属性。
属性三:order-by
1> <set>元素包含order-by属性,设置该属性后,Hibernate通过select语句到数据库中检索集合对象时,利用order-by子句进行排序(注:指定的是SQL语句的OrderBy子句,要写列名)。
2> order-by属性中可以加入SQL函数。