public List<Addcharge> findAddchggrpSeqList(final Integer unitinfoId, final AddchargeRateflgEnum rateflg,
final Integer addchargetypId, final Integer flag) {
return (List<Addcharge>) getHibernateTemplate().execute(new HibernateCriteriaCallback(Addcharge.class) {
protected Object doWithCriteria(Criteria c) {
c.add(Restrictions.eq("active", Boolean.TRUE)).add(Restrictions.eq("rateflg", rateflg));
if (ObjectUtils.isNotEmpty(unitinfoId)) {
c.add(Restrictions.eq("unitinfoId", unitinfoId));
}
if (ObjectUtils.isNotEmpty(addchargetypId)) {
c.add(Restrictions.eq("addchargetypId", addchargetypId));
}else{
if (flag.equals(1)) {
c.add(Restrictions.isNull("addchargetypId"));
} else if (flag.equals(2)) {
c.add(Restrictions.isNotNull("addchargetypId"));
}
}
c.add(Restrictions.isNotNull("maxnum"));
c.createCriteria("grpparameter",Criteria.LEFT_JOIN).addOrder(Order.asc("seq"));
c.addOrder(Order.asc("numericflg"));
c.addOrder(Order.asc("grpno"));
c.addOrder(Order.asc("seq"));
return c.list();
}
});
}
Criteria 实现左链接 同时排序
最新推荐文章于 2024-02-01 15:41:04 发布
这段代码展示了如何使用Hibernate的Criteria API进行左连接查询,并同时对查询结果进行多字段排序。通过设置不同条件,实现了根据单位信息ID、附加收费类型ID以及标志位筛选数据,确保结果中'active'为true且'rateflg'匹配指定状态。当附加收费类型ID为空时,根据标志位判断查询无ID或有ID的记录。最终,按照序列号、数值标志、组号和自定义序列进行升序排序。
摘要由CSDN通过智能技术生成