首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
SAAS
ToB门户
了解全球最新的ToB事件
论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
微博
Follow
记录
Doing
博客
Blog
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
排行榜
Ranklist
相册
Album
应用中心
qidao123.com ToB IT社区-企服评测·应用市场
»
论坛
›
软件与程序人生
›
后端开发
›
Java
›
SpringBoot事务相关备忘(方法添加@Transactional注解, ...
返回列表
发新帖
SpringBoot事务相关备忘(方法添加@Transactional注解,以及SQL语句(SQLSer
[复制链接]
发表于 2024-10-18 16:30:18
|
显示全部楼层
|
阅读模式
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
×
项目改用Spring Data JDBC 并手动
配置
DataSource之后,@Transactional注解一直不起作用。这两天研究了一下,注解不起作用,主要是没有
配置
TransactionManager 的事,
配置
完 TransactionManager 之后,@Transactional注解就起作用了。
但是配置完又发现,用jdbcTemplate.queryForList()方法实行SQL
代码
时,可以或许在遇到RAISERROR()的时候回滚,但用jdbcTemplate.update()/execute()方法时,却不能。
搜索了一阵,大概总结一下就是,queryForList()被计划为取得一个ResultSet,如果遇到RAISERROR(),那么方法会抛出非常,然后Spring看到这个unchecked exception(RuntimeException),就会回滚数据。
而execute()更通用,而且并不期望获得一个 ResultSet,遇到RAISERROR() 的时候,不需要立刻抛出非常,特殊是在已经乐成实行某些
代码
之后了。Spring没看到有非常,也就不需要回滚数据。
那么,如何在利用execute()方法,同时遇到RAISERROR()时,让数据也能回滚呢?尝试了一下
一篇问答
里提到的一种方法,就是在SQL语句开头中添加SET NOCOUNT ON; 就可以了,想想原来是跟之前操作返回多数据集一个做法。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复
使用道具
举报
返回列表
立山
+ 我要发帖
登录后关闭弹窗
登录参与点评抽奖 加入IT实名职场社区
去登录
微信订阅号
微信服务号
微信客服(加群)
H5
小程序
快速回复
返回顶部
返回列表