Hibernate HQL不返回合适的构造函数



我有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之前就看到过这个异常。据我回忆,这要么是因为没有无参数构造函数,要么是因为无参数构造函数没有公共访问权限,要么是由于实体类不可序列化。

尝试以下操作:

  1. 确保PaymentType类中有这些构造函数:

    /** 
     * Default, parameter-less constructor
     */
    public PaymentType() {
    }
    
  2. 也适用于Order:

    /** 
     * Default, parameter-less constructor
     */
    public Order() {
    }
    
  3. 确保PaymentTypeOrder都实现java.io.Serializable

最新更新