many to one could not resolve property

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

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值