事务入门(转账-1 场景引入)

本文详细介绍了数据库操作中的事务概念,包括其基本定义、ACID特性、典型应用场景如银行转账,并通过实例讲解了如何在项目中使用事务来确保数据的一致性和安全性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 是什么:

事务是数据库操作最基本的单元,逻辑上一组操作,要么都成功,如果有一个失败,则所有操作都失败

2. 典型场景:银行转账

3. 特性:(ACID)

(1)原子性:要么都成功要么都失败

(2)一致性:操作之前和操作之后的总量不变

(3)隔离性:多事务操作时候事务之间不会产生影响

(4)持久性:事务提交后数据表中的数据发生变化

  

一、建表

二、搭建项目:

 jdbcTemplate 注入 dataSource:

 daoImpl 注入 jdbcTemplate: 

service 注入 daoImpl:

三、具体实现

dao 添加接口:

daoImpl 重写 interface 接口:

service 业务层调用daoImpl数据层:

 四、单元测试:

刷新数据库,查看结果:

那么,问题来了!!!

如果lucy转出100以后,突然断网或者程序出现异常,mary是无法收到钱的,会出现如下异常:

异常模拟:

解决方案:事务操作

1. 开启事务

2. 业务操作

3. 没有异常,提交事务;出现异常,事务回滚

代码示范:

项目结构:

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值