版权声明:本文为博主原创文章,未经博主允许不得转载。 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