Hibernate/JPA中@ElementCollection如果没有@OrderColumn性能会降低

栏目: Hibernate · 发布时间: 5年前

内容简介:@ElementCollection是Hibernate/JPA中代表父子关系的多方注释,但是没有@OrderColumn的@ElementCollection插入和删除容易出现性能损失,而使用@OrderColumn性能变得更好。本应用程序展示了没有@OrderColumn使用@ElementCollection可能导致的性能损失。父实体:

@ElementCollection是Hibernate/JPA中代表父子关系的多方注释,但是没有@OrderColumn的@ElementCollection插入和删除容易出现性能损失,而使用@OrderColumn性能变得更好。

本应用程序展示了没有@OrderColumn使用@ElementCollection可能导致的性能损失。

父实体:

@Entity
<b>public</b> <b>class</b> ShoppingCart implements Serializable {

    <b>private</b> <b>static</b> <b>final</b> <b>long</b> serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    <b>private</b> Long id;

    <b>private</b> String name;
    
    @ElementCollection
    <b>private</b> List<String> products = <b>new</b> ArrayList<>();

这里的@ElementCollection并没有主键,@ElementCollection是映射到单独的数据表中。当你有很多插入和删除动作时,避免@ElementCollection,因为数据库为了实现加入或删除,得删除很多现有的行。数据表中数据项越多,性能损失越大。

测试源代码可以在 这里 找到  。

解决

通过添加@OrderColumn可以减少在集合尾部附近进行操作时的一些性能损失(例如,在集合末尾添加/删除)。主要是,位于添加/删除条目之前的所有元素都保持不变,因此如果我们影响靠近集合尾部的行,则可以忽略性能损失。

@Entity
<b>public</b> <b>class</b> ShoppingCart implements Serializable {

    <b>private</b> <b>static</b> <b>final</b> <b>long</b> serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    <b>private</b> Long id;

    @Column(name = <font>"name"</font><font>, nullable = false)
    <b>private</b> String name;
    
    @ElementCollection
    @OrderColumn(name = </font><font>"index_no"</font><font>)
    <b>private</b> List<String> products = <b>new</b> ArrayList<>();
</font>

测试源代码可以在 这里 找到  


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

IT大败局

IT大败局

Merrill R.Chapman、周良忠 / 周良忠 / 电子工业出版社 / 2004-8-1 / 35.00

这是一本由作者亲身经历写就的MBA式教案。通过作者那专业人士的敏锐、活泼流畅的文笔和美国人特有的幽默,本书为我们剖析了IT界十个有代表性且影响深远的愚蠢败局。这十个败局涉及企业经营的十个主要方面,它们是:产业标准的魔力,“缩水”产品的阴霾,产品定位的泥潭,市场关系的教训,巨型企业的困惑,企业并购的陷阱,品牌战略的迷茫,技术导向的失衡,企业公关的真谛和科技虚幻的诱惑。 书中有许多鲜为人......一起来看看 《IT大败局》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试