4 java spring jpa entitymanager sql-delete
我正在使用Spring框架来开展培训项目.我也在使用JPA,并且一直有一段时间.在我的DAO实现课中,我写道:
@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);
}
Run Code Online (Sandbox Code Playgroud)
正如您所看到的,它只是一个简单的DELETE语句,但我收到错误:
"Update/delete queries cannot be typed."
Run Code Online (Sandbox Code Playgroud)
我的猜测是,我需要使用一些EntityManager类方法来完成这项工作,但我不确定,因为在线这个错误几乎没有.我也很难应用我在网上找到的有关JPA删除查询的一些解决方案.任何关于正确方向的点或解释为什么抛出这个错误都非常感激.
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
Run Code Online (Sandbox Code Playgroud)
从这里,您可以清楚地看到,TypedQuery<T>由于第二个参数,您得到了一个.如果删除它,您将获得一个简单的Query对象.这就是你所需要的.
| 归档时间: |
|
| 查看次数: |
10411 次 |
| 最近记录: |