利用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");提出来作为公共的代码即可