Criteria 实现左链接 同时排序

这段代码展示了如何使用Hibernate的Criteria API进行左连接查询,并同时对查询结果进行多字段排序。通过设置不同条件,实现了根据单位信息ID、附加收费类型ID以及标志位筛选数据,确保结果中'active'为true且'rateflg'匹配指定状态。当附加收费类型ID为空时,根据标志位判断查询无ID或有ID的记录。最终,按照序列号、数值标志、组号和自定义序列进行升序排序。
摘要由CSDN通过智能技术生成
	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();
			}
		});
	}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值