这是question
的延续我将namedQuery命名为
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.
答案 0 :(得分:1)
可以在SELECT列表中使用构造函数来返回一个或多个Java实例。指定的类不需要是实体或映射到数据库。 构造函数名称必须是完全限定的。
SELECT NEW com.company.PublisherInfo(pub.id, pub.revenue, mag.price)
答案 1 :(得分:0)
我已设法解决错误,可能对其他人有用。
在namedQuery中而不是
select new Emp(o.empNo, o.empName) from Emp o
提供完全限定的班级名称,即<packagename>.<classname>
select new test.entity.Emp(o.empNo, o.empName) from Emp o
感谢。