`

many to one could not resolve property

 
阅读更多
来源:http://michaelfly.iteye.com/blog/772514

今天在做一个功能的时候 
遇到了。一个Could not resolve property 的问题。 

配置文件如下: 
Java代码  
<many-to-one name="user"  class="Users" column="StudentExam_user_fid" cascade="all" ></many-to-one>  

<many-to-one name="user"  class="Users" column="StudentExam_user_fid" cascade="all" ></many-to-one>

查询代码: 
Java代码  
Criteria crt = session.createCriteria(StudentExam.class).add(Restrictions.eq("exam.id", ExamId)).add(   
    Restrictions.eq("reading", reading)).add(Restrictions.like("user.truename", name));   
  
return crt.setFirstResult(start).setMaxResults(max).list();  

    Criteria crt = session.createCriteria(StudentExam.class).add(Restrictions.eq("exam.id", ExamId)).add(
        Restrictions.eq("reading", reading)).add(Restrictions.like("user.truename", name));

    return crt.setFirstResult(start).setMaxResults(max).list();

在网上找了好久。所有人给的理由都是“对照配置文件以及实体类,是否写错了字段名称” 
在我一再的确认下,字段名称没有任何错误…… 
而且使用user.id是可以进行查询的。除了这个以外。别的都不可以用! 
于是开始对配置文件进行修改。尝试了 lazy设置为false 等等。。想对应的修改 
Users配置文件的修改。未果 

最后,经过各种挣扎。以及Hibernate相关API的查找。最终终于找出解决办法 
Java代码  
Criteria crt = session.createCriteria(StudentExam.class).add(Restrictions.eq("exam.id", ExamId)).add(   
    Restrictions.eq("reading", reading)).createCriteria("user").add(Restrictions.like("truename", name));  

    Criteria crt = session.createCriteria(StudentExam.class).add(Restrictions.eq("exam.id", ExamId)).add(
        Restrictions.eq("reading", reading)).createCriteria("user").add(Restrictions.like("truename", name));

对。就是这样写。在使用完StudentExam里的属性后。Java代码  
.createCriteria("user")  

.createCriteria("user")设置到user实体里。然后再选择属性 
注:这里的user是StudentExam类中的名称 





具体写法:
public static Criteria setFiltrationParameter(Criteria criteria, Filtration... filtrations)
	{
		if (filtrations.length > 0)
		{
			List<Criterion> criterions = new ArrayList<Criterion>();
			for (Filtration filtration : filtrations)
			{
				Criterion criterion = null;
				if (!filtration.isMultiFilter())
				{  
					if(filtration.getFieldName().indexOf("-")>1){
					  String f = filtration.getFieldName();
					  String[] feilds = filtration.getFieldName().split("-");
					  criteria.createCriteria(feilds[0]).add(createCriterion(feilds[1], filtration.getFieldValue(), filtration.getMatchType()));  
                    }else{					
					  criterion = createCriterion(filtration.getFieldName(), filtration.getFieldValue(), filtration.getMatchType());
					  criterions.add(criterion);
                    }
				} else
				{
					//包含多个属性需要比较的情况,进行or处理.
					Disjunction disjunction = Restrictions.disjunction();
					for (String filedName : filtration.getFieldNames())
					{
						if(filedName.indexOf("-")>1){
							  String[] feilds = filtration.getFieldName().split("-");
							  criteria.createCriteria(feilds[0]).add(createCriterion(feilds[1], filtration.getFieldValue(), filtration.getMatchType()));  
		                }else{
						      criterion = createCriterion(filedName, filtration.getFieldValue(), filtration.getMatchType());
						      disjunction.add(criterion);
		                }
					}
					criterions.add(disjunction);
				}
			}
			for (Criterion criterion : criterions) 
			{
				criteria.add(criterion);
			}
		}

		return criteria;
	}

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics