博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
spring data jpa @Query注解中delete语句报错 : @Modifying注解的使用
阅读量:6497 次
发布时间:2019-06-24

本文共 2552 字,大约阅读时间需要 8 分钟。

spring data jpa @Query注解中delete语句报错

项目中需要删除掉表中的一些数据

@Query("delete from EngineerServices es where es.engineerId = ?1")

int deleteByEgId(String engineerId);
但是提示了错误

org.hibernate.hql.QueryExecutionRequestException: Not supported for DML operations

通过查阅相关的资料发现,对于执行update和delete语句需要添加@Modifying注解

@Modifying

@Query("delete from EngineerServices es where es.engineerId = ?1")
int deleteByEgId(String engineerId);
不过,添加之后运行又出现了另一个错误

nested exception is javax.persistence.TransactionRequiredException: Executing an update/delete query

发现缺少Transaction,于是添加@Transactional

@Modifying

@Transactional
@Query("delete from EngineerServices es where es.engineerId = ?1")
int deleteByEgId(String engineerId);

到此,这条delete语句终于可以成功的执行了。

代码示例:

package com.easy.kotlin.chapter11_kotlin_springboot.daoimport com.easy.kotlin.chapter11_kotlin_springboot.entity.Imageimport org.springframework.data.domain.Pageimport org.springframework.data.domain.Pageableimport org.springframework.data.jpa.repository.Modifyingimport org.springframework.data.jpa.repository.Queryimport org.springframework.data.repository.PagingAndSortingRepositoryimport org.springframework.data.repository.query.Paramimport org.springframework.transaction.annotation.Transactional/** Created by jack on 2017/7/17.@Query注解里面的value和nativeQuery=true,意思是使用原生的sql查询语句.sql模糊查询like语法,我们在写sql的时候是这样写的like '%?%'但是在@Query的value字符串中, 这样写like %?1%另外,要注意的是: 对于执行update和delete语句需要添加@Modifying注解 */interface ImageRepository : PagingAndSortingRepository
{ @Query("SELECT a from #{#entityName} a where a.isDeleted=0 and a.category like %?1%") fun findByCategory(category: String): MutableList
@Query("select count(*) from #{#entityName} a where a.isDeleted=0 and a.url = ?1") fun countByUrl(url: String): Int @Query("SELECT a from #{#entityName} a where a.isDeleted=0 and a.category like %:searchText%") fun search(@Param("searchText") searchText: String, pageable: Pageable): Page
@Query("SELECT a from #{#entityName} a where a.isDeleted=0 and a.isFavorite=1") fun findAllFavorite(pageable: Pageable): Page
@Query("SELECT a from #{#entityName} a where a.isDeleted=0 and a.isFavorite=1 and a.category like %:searchText%") fun searchFavorite(@Param("searchText") searchText: String, pageable: Pageable): Page
@Modifying @Transactional @Query("update #{#entityName} a set a.isFavorite=1 where a.id=?1") fun addFavorite(id: Long) @Modifying @Transactional @Query("delete from #{#entityName} a where a.id=?1") fun delete(id: Long)}

转载地址:http://gljyo.baihongyu.com/

你可能感兴趣的文章
UIScrollView中的手势
查看>>
递归和迭代的差别
查看>>
基于jquery的可拖动div
查看>>
可以简易设置文字内边距的EdgeInsetsLabel
查看>>
[詹兴致矩阵论习题参考解答]习题1.3
查看>>
Android Fragment的使用
查看>>
mysql半同步复制实现
查看>>
沙朗javascript总结一下(一)---基础知识
查看>>
js深入研究之函数内的函数
查看>>
LeetCode:4_Median of Two Sorted Arrays | 求两个排序数组的中位数 | Hard
查看>>
python之commands模块
查看>>
android应用开发--------------看RadioGroup源代码,写相似单选选项卡的集成控件(如底部导航,tab等等)...
查看>>
LeetCode - Binary Tree Level Order Traversal
查看>>
FTP协议完全详解
查看>>
【C语言天天练(十五)】字符串输入函数fgets、gets和scanf
查看>>
【环境配置】配置sdk
查看>>
accept()
查看>>
USB 2.0 Hub IP Core
查看>>
USB 2.0 OTG IP Core
查看>>
解读浮动闭合最佳方案:clearfix
查看>>