java – hibernate QueryException:无法解析spring petclinic示例应用程序中的属性
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java – hibernate QueryException:无法解析spring petclinic示例应用程序中的属性,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2289字,纯文字阅读大概需要4分钟。
内容图文
![java – hibernate QueryException:无法解析spring petclinic示例应用程序中的属性](/upload/InfoBanner/zyjiaocheng/749/3e78e43c0a634422a767b7b369059f85.jpg)
我有以下JPA方法:
@SuppressWarnings("unchecked")
public Collection<Owner> findByPetType(Integer typeID) {
Query query = this.em.createQuery("SELECT DISTINCT owner FROM Owner owner left join fetch owner.pets as pet WHERE pet.type_id LIKE :typeID");
query.setParameter("typeID", typeID + "%");
return query.getResultList();
}
它抛出以下错误消息:
org.hibernate.QueryException: could not resolve property: type_id of:
org.springframework.samples.petclinic.model.Pet [SELECT DISTINCT owner FROM
org.springframework.samples.petclinic.model.Owner owner left join fetch owner.pets
as pet WHERE pet.type_id LIKE :typeID];
nested exception is java.lang.IllegalArgumentException:
org.hibernate.QueryException: could not resolve property: type_id of:
org.springframework.samples.petclinic.model.Pet [SELECT DISTINCT owner FROM
org.springframework.samples.petclinic.model.Owner owner left join fetch owner.pets
as pet WHERE pet.type_id LIKE :typeID]
这是来自Spring petclinic示例应用程序,因此所有相关代码is at this link,包括数据库定义.我使用的是hsqldb和jpa,上面的findByPetType()方法是我写的,不在示例应用程序中.
任何人都可以告诉我如何修复代码,以便它不会产生此错误消息?
编辑:
我按照Alex的建议,将pet.type_id改为pet.type.现在它给我以下错误消息(typeID的值设置为1):
Parameter value [1%] did not match expected type
[org.springframework.samples.petclinic.model.PetType]; nested exception is
java.lang.IllegalArgumentException: Parameter value [1%] did not match expected type
[org.springframework.samples.petclinic.model.PetType]
第二次编辑:
我提出了Sergi Almar的建议,现在它抛出了以下错误:
Parameter value [1%] did not match expected type [java.lang.Integer]; nested exception
is java.lang.IllegalArgumentException: Parameter value [1%] did not match expected type
[java.lang.Integer]
我检查了,调用代码启动typeID为“Integer typeID = 1;”所以我不确定为什么它在这里看不到整数.
解决方法:
由于这是一个JPQL查询,您应该在查询中使用实体属性(Pet有一个具有id的PetType).以下代码将按预期执行:
@SuppressWarnings("unchecked")
public Collection<Owner> findByPetType(Integer typeID) {
Query query = this.em.createQuery("SELECT DISTINCT owner FROM Owner owner left join fetch owner.pets as pet WHERE pet.type.id = :typeID");
query.setParameter("typeID", typeID);
return query.getResultList();
}
内容总结
以上是互联网集市为您收集整理的java – hibernate QueryException:无法解析spring petclinic示例应用程序中的属性全部内容,希望文章能够帮你解决java – hibernate QueryException:无法解析spring petclinic示例应用程序中的属性所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。