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

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值