hibernate中重复显示问题的解决方法
来源:互联网 发布:苏联发展数据大全 编辑:程序博客网 时间:2024/05/17 02:22
下面是在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上也有一些值得一看的东西
- hibernate中重复显示问题的解决方法
- hibernate中数据重复显示问题的解决方法
- android中Toast重复显示bug解决方法
- NavigationView中headerLayout部分重复显示解决方法
- 关于Struts2.0中重复提交问题的解决方法
- 多线程中生成随机数序列重复问题的解决方法
- 多线程中生成随机数序列重复问题的解决方法
- 多线程中生成随机数序列重复问题的解决方法
- Hibernate中有关重复定义字段的问题
- Android中防止Toast重复显示的问题
- Fragment中嵌套listview重复显示的问题
- Toast重复显示的问题
- hibernate中Criteria的DISTINCT查询问题的解决方法
- word 2010 标题行重复设置方法及表格标题行无法重复显示问题的解决方法
- 使用Hibernate过程中所遇到的问题已经解决方法
- PowerDesigner中显示name, code,comment的解决方法 修正脚本,执行不会重复添加comment
- 解决按钮重复提交问题 (Jtable中重复显示数据)
- 标签控件中显示对话框出现的问题及解决方法
- DataSet进行批量更新
- j2me部分手机的bug
- ASP.NET组件编程step by step
- linux 信号(signal)介绍
- 用Visual C++开发数据库程序
- hibernate中重复显示问题的解决方法
- Windows消息大全
- 备份目录
- 一个简单的Web服务器
- [转]SERV-U 6002版安全设置全攻略(图文)
- VC常用数据类型列表
- c#·委托&事件
- 我的Blog~
- 如何将文件打包、压缩并分割成制定大小?