hibernate criteria 查找特定表中的distinct字段

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_31965095/article/details/72722761
select distinct 字段 from 表名; 

利用hibernate中的criteria使用distinct方法取出特定表中的重复字段。

public List<DAO> findDistinct() {
		log.debug("finding all DAO instances");
		Session session = getSession();	//生成Session实例
		Transaction tx = session.beginTransaction();	
		List<DAO> list = null ;
		try {
			list = session.createCriteria(DAO.class).add(Restrictions.sqlRestriction("rowid in (select min(a.rowid) from 你自己的表名 a group by a.需要去除重复的字段)")).list();
			tx.commit();//事务提交
			return list;
		} catch (RuntimeException re) {
			log.error("find all failed", re);
			if(tx!=null){
				tx.rollback();
			}
			throw re;
		}
	}
此方法查出来的List是类型是List<DAO>;

add(Restrictions.sqlRestriction("rowid in (select min(a.rowid) from 你自己的表名 a group by a.需要去除重复的字段)"));
Restrictions.sqlRestriction代表 where后面跟的语句,rowid是每张表必有的.所以通过子查询可以将条件过滤掉,只剩下a.重复的字段不重复的所有数据.碰到同样问题的朋友可以参考次方法解决。

参考网址:http://bbs.csdn.net/topics/380201403?page=1


猜你喜欢

转载自blog.csdn.net/qq_31965095/article/details/72722761
今日推荐