org.hibernate.QueryException: could not resolve property: p_phone_no 异常

此处p_phone_no 为表中的字段,PO中名称为pPhoneNo

		// 记录是否已经存在
		int count = web_PatientService.countByProperty("p_phone_no", pPhoneNo);
		if (count > 0) {
			return new ResultInfo(IConstant.FAILURE, "客户资料已经存在,请不要重复添加", false);
		}

参考来源:http://www.thinksaas.cn/group/topic/339990/

异常org.hibernate.QueryException: could not resolve property的原因

异常消息如下所示:

org.hibernate.QueryException: could not resolve property: task_no of: edu.cust.entity.Task

这里,关键是“task_no of: edu.cust.entity.Task”,task_no为数据库中表的字段,异常时说在查询的时候无法解析这个字段,也就是说这个字段是错误的。

由于Eclipse能够进行Hibernate映射,并自动生成持久化类和对应的配置文件,对于类似于task_no中带有下划线的字段,则自动将下划线去掉,task_no在持久化类中对应属性为taskNo,所以,在Dao中编写查询的方法中,必须写成

criteria.add(Restrictions.eq("taskNo",task.getTaskNo()));

这里eq()方法的第一个参数对应于持久化类中的属性名称,如果使用下面:

criteria.add(Restrictions.eq("task_no",task.getTaskNo()));

就可能发生上面的异常,千万要小心。

一般地,如果涉及到属性类型无法解析的异常,可能出现问题的地方有:

数据库字段与持久化类映射文件,以及持久化类文件中属性名称或者类型可能不相匹配;

持久化类映射文件中属性类型可能有问题,比如,如果使用Java类型,注意大写(如type="java.lang.String"),如果使用Hibernate类型,使用小写(如type="string")。

你可能感兴趣的:(org.hibernate.QueryException: could not resolve property: p_phone_no 异常)