现在的位置: 首页 > 综合 > 正文

hibernate使用list进行多对多关联时中间表的主键策略

2013年12月09日 ⁄ 综合 ⁄ 共 1356字 ⁄ 字号 评论关闭

在hibernate中,使用list的进行多对多关系映射时,中间表的主键并不是由两个外键作为联合主键的,而是由一个外键和一个索引列作为联合主键。
那么该hibernate会使用那个外键来作为联合主键呢?这会根据是否双向多对多,是否设置inverse属性和inverse属性设在哪一方而发生改
变。

1.双向多对多

考虑以下hiberante映射
ManyDoo.hbml.xml:

    <class name="bean.ManyDoo" table="Doo_T">
        <list name="manyFoos" table="foos_doos" cascade="save-update">
            <key column="doo_id" not-null="true"/>
            <index column="xl"/>
            <many-to-many class="bean.ManyFoo" column="foo_id"/>
        </list>
    </class>

ManyFoo.hbm.xml

    <class name="bean.ManyFoo" table="Foo_T">
        <list name="manyDoos" table="foos_doos" cascade="save-update">
            <key column="foo_id" not-null="true"/>
            <index column="xl"/>
            <many-to-many class="bean.ManyDoo" column="doo_id"/>
        </list>
    </class>

1)没有设置inverse属性

如果没有设置 inverse
属性,那么hibernate会使用 hibernate.cfg.xml
中顺序最后的那个映射配置的类的id作为联合主键。
比如 hiberante.cfg.xml
中这样写:

<mapping resource="bean/ManyDoo.hbm.xml"/>

<mapping resource="bean/ManyFoo.hbm.xml"/>

那么ManyFoo.hbm.xml
是在后面的,那么联合主键就是(foo_id, xl)

如果这样:

<mapping resource="bean/ManyFoo.hbm.xml"/>

<mapping resource="bean/ManyDoo.hbm.xml"/>


那么联合主键就是 (doo_id, xl)

2)设置了inverse属性

如果在一方设置了 inverse="true"
,那么另一方就成为联合主键的一部分。
比如,如果 ManyDoo.hbm.xml
中设置了 inverse="true"
,那么联合主键就是 (foo_id, xl)

如果 ManyFoo.hbm.xml
中设置了 inverse="true"
,那么联合主键就是 (doo_id, xl)

2.单向多对多

单向多对多很简单,设置了多对多的一方成为联合主键的一部分。
比如, ManyFoo.hbm.xml
中设置了多对多, ManyDoo.hbm.xml
中没有设置,那么联合主键就是 (foo_id, xl)

反之亦然。

【上篇】
【下篇】

抱歉!评论已关闭.