栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Hibernate

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Hibernate

在有关

ElementCollection
JPA Wikibook 的页面中以某种方式解释了该问题:

CollectionTable中的主键

JPA 2.0规范不提供一种方式来定义

Id
Embeddable
但是,要删除或更新
ElementCollection
映射的元素,
通常需要一些唯一的键。否则,在每次更新的JPA的供应商将需要删除一切从
CollectionTable
Entity
,然后插入值回。

因此,JPA提供程序将最有可能假定中的所有字段的
Embeddable
组合与外键组合是唯一的
JoinColunm
。但是,这可能效率低下,或者如果
Embeddable
规模较大或过于复杂,那将是不可行的。

而这恰好是这里的内容(粗体部分)(Hibernate不会为集合表生成主键,也无法检测集合中 哪些元素 已更改,并且将删除表中的旧内容以插入新内容)。

但是, 如果 定义一个

@OrderColumn
(以指定用于维护列表的持久顺序的列-
由于使用
List
,这将很有意义),则Hibernate将创建一个 主键 (由 order列和join列组成
)并且能够在不删除全部内容的情况下更新收藏表。

这样的事情(如果您想使用默认的列名):

@Entitypublic class Person {    ...    @ElementCollection    @CollectionTable(name = "PERSON_LOCATIONS", joinColumns = @JoinColumn(name = "PERSON_ID"))    @OrderColumn    private List<Location> locations;    ...}

参考文献

  • JPA 2.0规范
    • 第11.1.12节“ ElementCollection批注”
    • 第11.1.39节“ OrderColumn注释”
  • JPA Wikibook
    • Java持久性/ ElementCollection


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/383866.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号