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

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

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于多个关联的管理,以下是一些常见的方法和技巧: 1. 设计良好的数据库结构:首先,你需要设计一个合理的数据库结构,包括正确定义和设计之间的关系(如一对一、一对多、多对多关系)。确保每个都有适当的主键和外键,以便在关联数据能够正确地进行查询和操作。 2. 使用关联查询:关联查询是一种用于检索和操作多个关联数据的查询技术。通过使用 JOIN 语句,你可以将多个连接在一起,并根据关联条件检索相关数据。根据具体情况选择合适的 JOIN 类型(如 INNER JOIN、LEFT JOIN、RIGHT JOIN)来满足查询需求。 3. 使用外键约束:外键约束是一种数据库约束机制,用于确保关联之间的数据完整性。通过定义外键关系,你可以强制要求在插入或更新数据必须满足关联的条件。这可以防止意外删除或修改关联中的数据,保持数据的一致性和完整性。 4. 使用索引:对于经常进行关联查询的列,创建适当的索引可以提高查询性能。索引可以加快查询速度,减少数据扫描的开销。根据查询需求和频率,选择合适的列创建索引,但也要注意不要过度索引,以避免索引维护的开销。 5. 数据库连接池:如果应用程序需要频繁地访问多个关联使用数据库连接池可以提高性能和资源利用率。连接池可以缓存数据库连接,避免频繁地创建和释放连接,从而减少了连接的开销。 6. ORM(对象关系映射)工具:ORM 工具可以简化对多个关联进行管理的过程。ORM 工具将数据库映射为对象,并提供了方便的方法和接口来进行关联查询、数据修改和持久化等操作。常见的 ORM 框架包括 Hibernate(Java)、Entity Framework(.NET)、Django ORM(Python)等。 通过合理的数据库设计、优化查询和使用相关工具,你可以更好地管理多个关联,并且提高数据库操作的效率和准确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值