我有HQL查询
select new PaymentType(o.paymentType.idPaymentType) from Order as o where o.user='1'
它抛出以下异常
org.hibernate.PropertyNotFoundException: no appropriate constructor in class: PaymentType
at org.hibernate.util.ReflectHelper.getConstructor(ReflectHelper.java:187)
at org.hibernate.hql.classic.QueryTranslatorImpl.renderSQL(QueryTranslatorImpl.java:631)
at org.hibernate.hql.classic.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:220)
at org.hibernate.hql.classic.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:185)
at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:77)
at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:56)
at org.hibernate.engine.query.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:72)
at org.hibernate.impl.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:133)
at org.hibernate.impl.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:112)
at org.hibernate.impl.SessionImpl.createQuery(SessionImpl.java:1623)
但我已经声明了必需的构造函数,除此之外,还有其他声明的树构造函数具有不同的params计数和类型,也没有params构造函数。
public PaymentType(Integer idPaymentType) {
this.idPaymentType = idPaymentType;
}
编辑:
public class Order implements java.io.Serializable {
private Integer idOrder;
private PaymentType paymentType;
private DeliveryType deliveryType;
...
}
有两件事值得检查。1.尝试使用PaymentType 的完全限定名称
select new com.company.xxx.PaymentType(o.paymentType.idPaymentType)
2.还要确保实体Order中的id是int/integer,而不是Long或其他内容。
我在使用Hibernate之前就看到过这个异常。据我回忆,这要么是因为没有无参数构造函数,要么是因为无参数构造函数没有公共访问权限,要么是由于实体类不可序列化。
尝试以下操作:
-
确保
PaymentType
类中有这些构造函数:/** * Default, parameter-less constructor */ public PaymentType() { }
-
也适用于
Order
:/** * Default, parameter-less constructor */ public Order() { }
-
确保
PaymentType
和Order
都实现java.io.Serializable
。