Spring JDBC Template与事务管理:基于XML与注解的实战指南

news2025/3/26 9:46:58

摘要

本文深入解析Spring JDBC Template与事务管理的核心技术,结合XML配置注解方式两种主流方案,通过转账案例完整演示数据库操作与事务管理的最佳实践。文章涵盖JDBC Template的核心用法、事务配置语法、常见问题及性能优化建议,帮助开发者快速掌握Spring在数据层的高效应用。

一、Spring JDBC Template核心功能

JdbcTemplate是Spring框架对原生JDBC的封装,通过简化资源管理(如连接释放、异常处理)和模板化操作,大幅降低数据库开发复杂度。其核心方法包括:

  • execute():执行任意SQL(如DDL语句)。

  • update():处理增删改操作,支持预编译参数。

  • query():执行查询并映射结果集到对象。

  • call():调用存储过程。

优势:
  • 避免资源泄漏:自动管理数据库连接。

  • 统一异常处理:将检查异常转换为非检查异常(DataAccessException)。

  • 简化代码:减少重复的try-catch和资源关闭逻辑。


二、JDBC Template实战:增删改查操作

1. 配置数据源与JdbcTemplate

Spring.xml中定义数据源和JdbcTemplate:

<!-- 数据源配置 -->  
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">  
    <property name="driverClassName" value="com.mysql.jdbc.Driver"/>  
    <property name="url" value="jdbc:mysql://localhost:3306/mybatis_db"/>  
    <property name="username" value="root"/>  
    <property name="password" value="123"/>  
</bean>  

<!-- JdbcTemplate配置 -->  
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">  
    <property name="dataSource" ref="dataSource"/>  
</bean>  
2. 增删改查示例
public class UserTest {  
    @Test  
    public void testInsert() {  
        String sql = "INSERT INTO user(username, address) VALUES('李连杰', '上海')";  
        jdbcTemplate.execute(sql);  
    }  

    @Test  
    public void testUpdate() {  
        String sql = "UPDATE user SET username='稳杰' WHERE id=?";  
        int rows = jdbcTemplate.update(sql, 2);  
        System.out.println("更新行数:" + rows);  
    }  

    @Test  
    public void testQuery() {  
        String sql = "SELECT * FROM user WHERE address LIKE '%京%'";  
        List<User> users = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class));  
        users.forEach(System.out::println);  
    }  
}  

三、Spring事务管理核心概念

1. 事务的ACID特性
  • 原子性(Atomicity):事务内的操作要么全部成功,要么全部回滚。

  • 一致性(Consistency):事务前后数据库状态保持一致。

  • 隔离性(Isolation):并发事务间互不干扰。

  • 持久性(Durability):事务提交后数据永久保存。

2. Spring事务管理接口
  • PlatformTransactionManager:事务管理器的核心接口。

  • TransactionDefinition:定义事务属性(传播行为、隔离级别等)。

  • TransactionStatus:事务运行时状态。


四、基于XML配置实现事务管理

1. 配置事务管理器与AOP
<!-- 事务管理器 -->  
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
    <property name="dataSource" ref="dataSource"/>  
</bean>  

<!-- 事务通知 -->  
<tx:advice id="txAdvice" transaction-manager="txManager">  
    <tx:attributes>  
        <tx:method name="transfer" propagation="REQUIRED" isolation="DEFAULT" read-only="false"/>  
    </tx:attributes>  
</tx:advice>  

<!-- AOP配置 -->  
<aop:config>  
    <aop:pointcut id="txPointcut" expression="execution(* com.qcby.entity.AliPayDaoImpl.transfer(..))"/>  
    <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>  
</aop:config>  
2. 事务传播行为与隔离级别
  • 传播行为

    • REQUIRED(默认):当前存在事务则加入,否则新建。

    • REQUIRES_NEW:始终新建事务,挂起当前事务。

  • 隔离级别

    • DEFAULT:使用数据库默认级别。

    • READ_COMMITTED:避免脏读。


五、基于注解方式实现事务管理

1. 启用注解驱动
<!-- 开启注解事务 -->  
<tx:annotation-driven transaction-manager="txManager"/>  
2. 使用@Transactional注解
public class AliPayDaoImpl implements AlipayDao {  
    @Override  
    @Transactional(  
        propagation = Propagation.REQUIRED,  
        isolation = Isolation.DEFAULT,  
        rollbackFor = Exception.class  
    )  
    public void transfer(String fromA, String toB, int amount) {  
        jdbcTemplate.update("UPDATE alipay SET amount = amount-? WHERE aliname=?", amount, fromA);  
        // 模拟异常  
        // int a = Integer.parseInt("error");  
        jdbcTemplate.update("UPDATE alipay SET amount = amount+? WHERE aliname=?", amount, toB);  
    }  
}  
3. 注解配置注意事项
  • 方法可见性@Transactional仅对public方法生效。

  • 异常回滚:默认仅回滚RuntimeException,需通过rollbackFor指定其他异常。


六、总结与最佳实践

1. XML vs 注解
场景XML配置注解方式
集中管理适合多事务方法统一配置适合分散在代码中的事务声明
灵活性修改需重新部署动态调整,无需重启
代码侵入性无侵入需在代码中添加注解
2. 最佳实践
  • 事务粒度:尽量细化到方法级别,避免长事务。

  • 异常处理:明确指定rollbackFor,避免事务意外提交。

  • 性能优化:合理选择隔离级别,避免过度使用SERIALIZABLE


关键词:Spring JDBC Template、事务管理、XML配置、@Transactional、传播行为、隔离级别

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2320821.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Keil5-开发技巧】

Keil5-开发技巧 ■ Keil5利用AStyle插件格式化代码第一步:下载AStyle插件第二步:添加AStyle插件第三步:AStyle插件介绍■ 一键转UTF-8编码■ Keil5利用AStyle插件格式化代码 第一步:下载AStyle插件 AStyle下载 第二步:添加AStyle插件 解压后 astyle-3.6.7-x64 在重命…

电脑上不了网普通用户排除方法

1&#xff1a;首先通过电脑的运行/CMD/ipconfig /all 命令查看电脑的ip地址是否正常如图&#xff1a; 2&#xff1a;在命令行中运行&#xff1a;ping 127.0.0.1 如图则正常&#xff0c;否则要重新安装网卡驱动 程序。 3&#xff1a;用ping命令&#xff0c;ping一下同网段的电…

【C#】WinForm自定义控件及窗体

前言 WinForm&#xff08;Windows Forms&#xff09;是Microsoft.NET框架中的技术&#xff0c;用于开发Windows桌面应用程序。它提供了一套丰富的控件和组件。通过拖放控件、编写事件处理程序等方式快速构建用户界面。 通过属性窗口定制这些控件的外观和行为。 通过数据绑定&am…

基于虚拟知识图谱的语义化决策引擎

在数字化转型浪潮中&#xff0c;企业数据资产的价值释放面临两大挑战&#xff1a;海量异构数据的整合困局与业务-技术语义鸿沟。本文解析飞速创软灵燕智能体平台的创新解决方案——通过构建业务语义驱动的虚拟知识图谱系统&#xff0c;实现企业数据的智能认知与决策赋能。 一、…

HarmonyOS:@AnimatableExtend 装饰器自学指南

在最近的项目开发中&#xff0c;我遇到了需要实现复杂动画效果的需求。在探索解决方案的过程中&#xff0c;我发现了 AnimatableExtend 装饰器&#xff0c;它为实现动画效果提供了一种非常灵活且强大的方式。然而&#xff0c;在学习这个装饰器的过程中&#xff0c;我发现相关的…

kubernetes|云原生|kubeadm-1.25.7集群单master+外部etcd集群+kubeadm-init+cri-docker文件形式快速部署

一、 前言和写作原因 本文做一个kubernetes集群部署记录&#xff0c;实在是部署的东西太多了&#xff0c;害怕忘记&#xff0c;kubernetes集群的部署又细节比较多&#xff0c;因此&#xff0c;在这里做一个尽量详细的记录 三个VMware虚拟机&#xff0c;IP分别为192.168.123.…

Qt 导入TagLib库

文章目录 0. 前言和环境介绍1. 下载TagLib2. 下载zlib3. 修改.pro文件4. 测试代码 0. 前言和环境介绍 最近在使用Qt写一个播放器&#xff0c;需要解析mp3文件&#xff0c;于是研究了一下如何导入TagLib库 Qt构建套件:Desktop Qt6.8.2 MinGW64-bit Qt Creator安装目录: D:\bit…

新能源汽车充换站如何实现光储充一体化管理?

长三角某换电站光伏板晒到发烫&#xff0c;却因电网限电被迫切机&#xff1b;北京五环充电站每月多缴6万超容费&#xff1b;深圳物流车充电高峰排队3小时...当95%的充换站深陷“用不起绿电、扛不住扩容、算不清碳账”困局&#xff0c;安科瑞用一组真实数据撕开行业潜规则&#…

【数据分享】2000—2024年我国省市县三级逐年归一化植被指数(NDVI)数据(年平均值/Shp/Excel格式)

之前我们分享过2000-2024年我国逐年的归一化植被指数&#xff08;NDVI&#xff09;栅格数据&#xff0c;该逐年数据是取的当年月归一化植被指数&#xff08;NDVI&#xff09;的年平均值。&#xff01;该数据来源于NASA定期发布的MOD13A3数据集&#xff01;很多小伙伴拿到数据后…

【leetcode题解】链表

目录 链表 两数相加 两两交换链表中的节点 重排链表 合并 K 个升序链表&#xff08;困难&#xff09; K 个一组翻转链表 链表 1. 常用技巧 画图&#xff01;&#xff01;&#xff01;&#xff08;直观形象&#xff0c;便于我们理解&#xff09;引入虚拟“头”节点&#xf…

Windows打开ftp局域网共享

前提是windows已经设置好开机账号密码了&#xff0c;否则教程不适用 第一先打开电脑ftp共享配置 点击保存即可 2.设置要共享到其他电脑的文件路径&#xff08;如果你要共享整个盘你就设置整个盘&#xff0c;如果是共享盘中某文件就设置某文件&#xff0c;这里是某文件&#x…

我爱学算法之——滑动窗口攻克子数组和子串难题(中)

学习算法&#xff0c;继续加油&#xff01;&#xff01;&#xff01; 一、将 x 减到 0 的最小操作数 题目解析 来看这一道题&#xff0c;题目给定一个数组nums和一个整数x&#xff1b;我们可以在数组nums的左边或者右边进行操作&#xff08;x减去该位置的值&#xff09;&#…

从零开始上手huggingface

1. 环境配置 # git 安装&#xff1a;https://git-scm.com/ # git lfs安装&#xff1a;https://git-lfs.com git lfs install # huggingface-cli 安装&#xff1a;https://huggingface.co/docs/hub/index pip install huggingface_hub2. 网站直接下载模型 可能会中断&#xff…

用 pytorch 从零开始创建大语言模型(六):对分类进行微调

用 pytorch 从零开始创建大语言模型&#xff08;六&#xff09;&#xff1a;对分类进行微调 6 微调用于分类6.1 微调的不同类别6.2 准备数据集6.3 创建数据加载器6.4 使用预训练权重初始化模型6.5 添加分类头部6.6 计算分类损失和准确率6.7 在监督数据上微调模型6.8 使用LLM进…

Netty——BIO、NIO 与 Netty

文章目录 1. 介绍1.1 BIO1.1.1 概念1.1.2 工作原理1.1.3 优缺点 1.2 NIO1.2.1 概念1.2.2 工作原理1.2.3 优缺点 1.3 Netty1.3.1 概念1.3.2 工作原理1.3.3 优点 2. Netty 与 Java NIO 的区别2.1 抽象层次2.2 API 易用性2.3 性能优化2.4 功能扩展性2.5 线程模型2.6 适用场景 3. 总…

【Linux】信号:信号保存和处理

&#x1f525;个人主页&#xff1a;Quitecoder &#x1f525;专栏&#xff1a;linux笔记仓 目录 01.阻塞信号信号集 02.捕捉信号sigaction可重入函数volatileSIGCHLD 01.阻塞信号 实际执行信号的处理动作称为信号递达&#xff1a;每个信号都有一个默认行为&#xff0c;例如终…

应用权限组列表

文章目录 使用须知位置相机麦克风通讯录日历运动数据身体传感器图片和视频音乐和音频跨应用关联设备发现和连接剪切板文件夹文件(deprecated) 使用须知 在申请目标权限前&#xff0c;建议开发者先阅读应用权限管控概述-权限组和子权限&#xff0c;了解相关概念&#xff0c;再合…

MATLAB实现基于“蚁群算法”的AMR路径规划

目录 1 问题描述 2 算法理论 3 求解步骤 4 运行结果 5 代码部分 1 问题描述 移动机器人路径规划是机器人学的一个重要研究领域。它要求机器人依据某个或某些优化原则 (如最小能量消耗&#xff0c;最短行走路线&#xff0c;最短行走时间等)&#xff0c;在其工作空间中找到一…

【深度学习】多目标融合算法(五):定制门控网络CGC(Customized Gate Control)

目录 一、引言 二、CGC&#xff08;Customized Gate Control&#xff0c;定制门控网络&#xff09; 2.1 技术原理 2.2 技术优缺点 2.3 业务代码实践 2.3.1 业务场景与建模 2.3.2 模型代码实现 2.3.3 模型训练与推理测试 2.3.4 打印模型结构 三、总结 一、引言 上一…

【NLP 42、实践 ⑪ 用Bert模型结构实现自回归语言模型的训练】

如果结局早已注定&#xff0c;那么过程就将大于结局 —— 25.3.18 自回归语言模型&#xff1a;由前文预测后文的语言模型 特点&#xff1a;单向 训练方式&#xff1a;利用前n个字预测第n1个字&#xff0c;实现一个mask矩阵&#xff0c;送入Bert模型&#xff0c;让其前文看不到…