Hibernate的数据映射关系

1单向 关系 ,1 - N 1 - 1 N-1 N -N

a 单向N-1,只需要从N的一端 访问到 1的一端,1 特指公共的地方,
使用方法:在N的一端增加一个1的实体

(1)无连接表映射,在N的的一端数据表增加一个外键列,
(2)有连接表映射,强制利用join产生连接表,
<join table="" >
        <key column=""/>
        name 表示类中属性的名字
        to-one name="" column="" class="" cascade=""/>
    join>

b 单向 1-1 只是将N-1 的N端 设置为 唯一,即 设置属性 unique=”true”
1、基于外键 2、基于连接表

c 单向 1-N 基于一个集合属性,少用 1-N单向关联,多用1—N双向关联
使用方法 在 1 的一端添加集合属性
1 无连接表的连接

<set name="addresses">
        <key column="person_id"/>
        to-many class="Address"/>
    set>

2 有连接表的1- N 单向关联 ,使用 ,将unique设置为 true

<set name="addresses" table="person_address">
            <key column="person_id"/>
            to-many  class="Address" column="address_id" unique="true"/>
set>

d 单向 N - N 端 必须用 连接表,并且控制端 添加 set 属性

<set name="addresses" table="person_address">
            <key column="person_id"/>
            to-many class="" column="" />
        set>

双向 1-N ,Hibernate推荐使用双向 1—N,并且 N这一端为 控制端

a 双向 1-N ,在 1的一端 增加 N ,在N的一端 增加 1,并且 1 为外键,

(1)无连接表的双向 1-N
1端操作






N端操作

to-one name="person" column="person_id" class="person" not-null="true" />

持久化 1-N关系,先 持久化 1 ,然后 通过N端设置1端,建立关联关系。

(2)有连接表的双向 1—N
    1 的一端 设置为 many-to-many  unique设置为 1 
    
        
        
    

    N 的一端 设置为 join
    
        
        
    

b 双向 N - N
使用方法 两端 都添加 set 属性,必须使用连接表


    
    


另外一个N端 对

`

你可能感兴趣的:(JavaEE)