我想知道,如果您在创建查询时获取所有内容,那么您可以在映射文件中的fetch=select元素上设置order-by属性。这样安全吗?
我的意思是,他们将结果放入HashSet中,我不认为这不能保证元素的顺序吗?
发布于 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不保证元素顺序。
https://stackoverflow.com/questions/7303170
复制相似问题