hibernate中重复显示问题的解决方法

下面是在hibernate中解决重复记录显示的一些思考
1.criterion.setResultTransformer(CriteriaSpecification.DISTINCT_ROOT_ENTITY)可以部分解决这个这问题,若结果需要分页显示这就无能为力了,因为这在内存中过滤重复的显示,分页显示结果总数就不准确了。
2.criteria.setProjection(Projections.distinct(Projections.id()))只能指定某一个字段为distinct,无法指定过滤某个对象
3.简单的hql也只能指定单个字段为distinct,无法指定某个对象为distinct
4.只能通过子查询来解决这个问题,hql语句的子查询的示例如下:
  from User u where u.id in (select u2.id from User u2, UserGroup ug where u2.group=ug and ug.name=?) order by u.name asc
5.因为我一直倾向于使用criterion来解决查询问题,而且criterion也提供支持子查询的Subqueries类,没想到在使用Subqueries的时候遇到了莫名奇妙的bug,在子查询语句中无法关联对象
  比如上面的hql语句中,在使用criterion的时候,就会丢掉UserGroup对象
  示例代码:
  DetachedCriteria subquery = DetachedCriteria.forClass(User.class);
  subquery.setProjection(Projections.property("id"));
  subquery.createCriteria("UserGroup").add(Restrictions.eq("name", groupName));
 
  DetachedCriteria criteria = DetachedCriteria.forClass(User.class);
  criteria.add(Subqueries.propertyIn("id", subquery))
  getHibernateTemplate().findByCriteria(criteria);
  上面的criterion语句在执行的时候,解析出的sql语句就会把UserGroup对应的T_UserGroup表丢掉,但是T_UserGroup.name的查询条件没丢,当然这样可定要报错的,不知道什么原因?(这个bug已经在hibernate-3.2.6版本中得到了修复)

6.在http://opensource.atlassian.com/projects/hibernate/browse/HB-520有一些讨论,虽然是讨论hibrenate2的版本,但还是值得一看的
7.在http://www.jroller.com/page/RickHigh?entry=hibernate_query_getting_rid_of上也有一些值得一看的东西
 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1. Hibernate配置文件的位置和内容? Hibernate的配置文件名为hibernate.cfg.xml,一般放在src目录下。配置文件包含了数据库连接信息、映射文件信息、缓存信息等。 2. Hibernate如何进行事务操作? Hibernate的事务操作需要先开启事务,然后通过Session的操作完成数据库操作,最后提交或回滚事务。 3. Hibernate如何进行对象关系映射? Hibernate通过XML配置文件或注解方式来进行对象关系映射。XML配置文件需要指定对象与表的映射关系、属性与字段的映射关系等。 4. Hibernate如何进行缓存管理? Hibernate提供了一级缓存和二级缓存。一级缓存是Session级别的缓存,二级缓存是SessionFactory级别的缓存。可以通过配置文件来启用二级缓存,并指定缓存策略。 5. Hibernate如何进行延迟载? Hibernate可以通过在映射文件指定lazy属性来进行延迟载。当需要使用关联对象时才会进行载,避免了一次性载所有数据的开销。 6. Hibernate的懒载有哪些问题Hibernate的懒载可能会导致N+1次查询问题,即在查询关联对象时需要执行多次查询,造成性能问题。可以通过Fetch策略来解决问题。 7. Hibernate如何进行SQL查询? Hibernate可以通过Criteria API或HQL来进行SQL查询。其Criteria API提供了面向对象的查询方式,HQL则提供了类似SQL的查询语言。 8. Hibernate如何进行连接池配置? Hibernate可以通过配置文件来配置连接池。可以指定连接池大小、最大等待时间、最大空闲时间等参数。 9. Hibernate如何进行多表查询? Hibernate可以通过Criteria API或HQL来进行多表查询。可以通过关联查询、子查询等方式来实现多表查询。 10. Hibernate如何进行分页查询? Hibernate可以通过Criteria API或HQL来进行分页查询。可以指定每页的记录数、当前页数等参数。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值