首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Hibernate集合元素order-by子句

Hibernate集合元素order-by子句
EN

Stack Overflow用户
提问于 2011-09-05 09:21:49
回答 1查看 6.3K关注 0票数 1

我想知道,如果您在创建查询时获取所有内容,那么您可以在映射文件中的fetch=select元素上设置order-by属性。这样安全吗?

我的意思是,他们将结果放入HashSet中,我不认为这不能保证元素的顺序吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-09-05 14:59:14

Hibernate实际上并不会将结果放入HashSet中,它会用自己的Set实现替换任何现有的HashSet

当您通过调用

()使实例持久化时,Hibernate实际上会用Hibernate自己的Set实现的实例替换HashSet。

http://docs.jboss.org/hibernate/core/3.6/reference/en-US/html/collections.html

如果您使用order-by属性,那么它将不会使用HashSet,而可能会使用LinkedHashSet。参考我上面引用的同一文档中的内容:

如果希望数据库本身对集合元素进行排序,请使用set、bag或map映射的order-by属性。这个解决方案是使用LinkedHashSet或LinkedHashMap实现的,它在SQL查询中执行排序,而不是在内存中。

因此,Hibernate将安全地维护Set中的项的顺序-但在创建新对象和持久化它们时要小心。如果在新对象中使用HashSet而不是LinkedHashSet,那么Hibernate将以基本上随机的顺序持久化您的集合,因为HashSet不保证元素顺序。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7303170

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档