Update/delete 无法键入查询 JPA
Update/delete queries cannot be typed JPA
我正在使用 Spring 框架来处理培训项目。我也在使用 JPA,并且一直玩得很开心。在我的 DAO 实现 class 中,我写了:
@Override
public void deleteEntries(Module mod) {
System.out.println(mod.getDescription());
entityManager.createQuery("delete from TrainingEntry e where e.module = :mod and e.completedDate IS NULL",
TrainingEntry.class).setParameter("mod", mod);
}
如您所见,这只是一个简单的 DELETE 语句,但我得到了错误:
"Update/delete queries cannot be typed."
我的猜测是,我需要使用一些 EntityManager
class 方法来完成这项工作,但我不确定,因为网上几乎没有关于此错误的信息。我也很难应用我在网上找到的关于 JPA 删除查询的一些解决方案。非常感谢任何关于正确方向或解释为什么抛出此错误的观点。
尝试在调用 createQuery() 时删除 TrainingEntry.class
参数,因为这是使其成为 "typed" 查询的原因。
EntityManager
方法的声明如下:
Query createQuery(java.lang.String qlString)
<T> TypedQuery<T> createQuery(java.lang.String qlString, java.lang.Class<T> resultClass)
// The other three method is not relevant here
由此,您可以清楚地看到,由于第二个参数,您得到了 TypedQuery<T>
。如果删除它,您将得到一个简单的 Query
对象。这就是你需要的。
entityManager.createQuery("delete from TrainingEntry e where e.module = :mod and e.completedDate IS NULL").setParameter("mod", mod);
我正在使用 Spring 框架来处理培训项目。我也在使用 JPA,并且一直玩得很开心。在我的 DAO 实现 class 中,我写了:
@Override
public void deleteEntries(Module mod) {
System.out.println(mod.getDescription());
entityManager.createQuery("delete from TrainingEntry e where e.module = :mod and e.completedDate IS NULL",
TrainingEntry.class).setParameter("mod", mod);
}
如您所见,这只是一个简单的 DELETE 语句,但我得到了错误:
"Update/delete queries cannot be typed."
我的猜测是,我需要使用一些 EntityManager
class 方法来完成这项工作,但我不确定,因为网上几乎没有关于此错误的信息。我也很难应用我在网上找到的关于 JPA 删除查询的一些解决方案。非常感谢任何关于正确方向或解释为什么抛出此错误的观点。
尝试在调用 createQuery() 时删除 TrainingEntry.class
参数,因为这是使其成为 "typed" 查询的原因。
EntityManager
方法的声明如下:
Query createQuery(java.lang.String qlString)
<T> TypedQuery<T> createQuery(java.lang.String qlString, java.lang.Class<T> resultClass)
// The other three method is not relevant here
由此,您可以清楚地看到,由于第二个参数,您得到了 TypedQuery<T>
。如果删除它,您将得到一个简单的 Query
对象。这就是你需要的。
entityManager.createQuery("delete from TrainingEntry e where e.module = :mod and e.completedDate IS NULL").setParameter("mod", mod);