org.springframework.orm.hibernate5.HibernateQueryException: duplicate alias: r; nested exception is

利用ssh框架做离线分页查询时碰到的多表查询的时候如果使用hibernate的DetachedCriteria会有如下异常 

org.springframework.orm.hibernate5.HibernateQueryException: duplicate alias: r; nested exception is org.hibernate.QueryException: duplicate alias: r
	at org.springframework.orm.hibernate5.SessionFactoryUtils.convertHibernateAccessException(SessionFactoryUtils.java:176)
	at org.springframework.orm.hibernate5.HibernateTemplate.doExecute(HibernateTemplate.java:344)
	at org.springframework.orm.hibernate5.HibernateTemplate.executeWithNativeSession(HibernateTemplate.java:309)
	at org.springframework.orm.hibernate5.HibernateTemplate.findByCriteria(HibernateTemplate.java:1004)

 该问题主要是在hibernate在离线查询时出现别名重复

通过查阅资料发现:用DetachedCriteria或者Criteria,使用CreateAlias时,如果第2个参数alias与之前添加的重复,则会报系统异常。


			if(StringUtils.isNoneBlank(province)){
				//添加过滤条件,根据省份模糊查询----多表关联查询,使用别名方式实现
				//参数一;分区对象中关联的区域对象属性名称
				//参数二;别名
				dc.createAlias("region","r");
				dc.add(Restrictions.like("r.province","%"+province+"%"));
			}
			
			if(StringUtils.isNoneBlank(city)){
				//添加过滤条件,根据市模糊查询----多表关联查询,使用别名方式实现
				//参数一;分区对象中关联的区域对象属性名称
				//参数二;别名
				dc.createAlias("region","r");
				dc.add(Restrictions.like("r.city","%"+city+"%"));
			}
			
			if(StringUtils.isNoneBlank(district)){
				//添加过滤条件,根据区模糊查询----多表关联查询,使用别名方式实现
				//参数一;分区对象中关联的区域对象属性名称
				//参数二;别名
				dc.createAlias("region","r");
				dc.add(Restrictions.like("r.district","%"+district+"%"));
			}

所以当我们要查询一个关联表的某些字段时只需要用一个别名就好,把dc.createAlias("region","r");提出来作为公共的代码即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值