来源:[url]http://michaelfly.iteye.com/blog/772514[/url]
具体写法:
今天在做一个功能的时候
遇到了。一个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;
}
本文详细介绍了在使用Hibernate进行数据库操作时遇到无法使用特定字段进行查询的问题,通过调整配置文件及实体类的写法,最终找到解决方案。包括使用createCriteria方法在实体类中设置条件,并提供了过滤参数的通用方法实现复杂查询。
1972

被折叠的 条评论
为什么被折叠?



