Update/delete queries cannot be typed JPA(UPDATE/DELETE查询不能键入JPA)
本文介绍了UPDATE/DELETE查询不能键入JPA的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在使用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);
}
如您所见,这只是一个简单的DELETE语句,但我得到错误:
"Update/delete queries cannot be typed."
我的猜测是,我需要使用一些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
从这里可以清楚地看到,由于第二个参数,您得到了TypedQuery<T>
。如果删除它,您将得到一个简单的Query
对象。这就是你所需要的。
这篇关于UPDATE/DELETE查询不能键入JPA的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:UPDATE/DELETE查询不能键入JPA


基础教程推荐
猜你喜欢
- REST Web 服务返回 415 - 不支持的媒体类型 2022-01-01
- Spring AOP错误无法懒惰地为此建议构建thisJoinPoin 2022-09-13
- 使用堆栈算法进行括号/括号匹配 2022-01-01
- 如何对 Java Hashmap 中的值求和 2022-01-01
- 无法复制:“比较方法违反了它的一般约定!" 2022-01-01
- RabbitMQ:消息保持“未确认"; 2022-01-01
- 问题http://apache.org/xml/features/xinclude测试日志4j 2 2022-01-01
- 修改 void 函数的输入参数,然后读取 2022-01-01
- 存储 20 位数字的数据类型 2022-01-01
- Struts2 URL 无法访问 2022-01-01