在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)
反之亦然。