这是该question的延续

我命名为

select new Emp(o.empNo, o.empName)  from Emp o


和构造函数定义为

public Emp(String empNo, String empName) {
    this.empNo= empNo;
    this.empName= empName;
}


执行时出现错误

Exception [TOPLINK-8013] (Oracle TopLink Essentials - 2.1
(Build b52-fcs (09/24/2008))):
oracle.toplink.essentials.exceptions.EJBQLException
Exception Description: Error compiling the query [Emp.findAll:
select new Emp(o.empNo, o.empName)  from Emp o ], line 1, column 9:
constructor class [Emp] not found.

最佳答案

http://openjpa.apache.org/builds/1.2.0/apache-openjpa-1.2.0/docs/manual/jpa_langref.html#jpa_langref_constructor

SELECT列表中可以使用构造函数来返回一个或多个Java实例。指定的类不需要是实体,也不必映射到数据库。构造函数名称必须完全合格。

SELECT NEW com.company.PublisherInfo(pub.id, pub.revenue, mag.price)

10-07 23:31