当前位置:网站首页>5.事务管理
5.事务管理
2022-08-02 14:10:00 【鱼子酱:P】
1.事务特性

2.事务的隔离性
- 常见的并发异常
- 第一类丢失更新、第二类丢失更新。
- 脏读、不可重复读、幻读。
第一类丢失更新:某一个事务的回滚,导致另外一个事务已更新的数据丢失了。

第二类丢失更新:某一个事务的提交,导致另外一个事务已更新的数据丢失了。

脏读:某一个事务,读取了另外一个事务未提交的数据。

不可重复读:某一个事务,对同一个数据前后读取的结果不一致。 (查询一条数据结果不一致)

幻读:某一个事务,对同一个表前后查询到的行数不一致。(查询多条数据结果不一致)

- 常见的隔离级别
- Read Uncommitted:读取未提交的数据。
- Read Committed:读取已提交的数据。
- Repeatable Read:可重复读。
- Serializable:串行化。

3.实现机制
- 悲观锁(数据库)
- 共享锁(S锁)
事务A对某数据加了共享锁后,其他事务只能对该数据加共享锁,但不能加排他锁。 - 排他锁(X锁)
事务A对某数据加了排他锁后,其他事务对该数据既不能加共享锁,也不能加排他锁。
- 共享锁(S锁)
- 乐观锁(自定义)
- 版本号、时间戳等
在更新数据前,检查版本号是否发生变化。若变化则取消本次更新,否则就更新数据(版本号+1)。
- 版本号、时间戳等
4.Spring事务管理
无论底层什么数据库,它的api都是一套
- 声明式事务
- 通过XML配置,声明某方法的事务特征。(本项目用这个)
- 通过注解,声明某方法的事务特征。
- 编程式事务
- 通过 TransactionTemplate 管理事务,并通过它执行数据库的操作。
声明式事务
在 @Transactional 注解上定义隔离机制和传播机制。当save1()方法中出现错误后,整个方法回滚,插入数据库失败。
// REQUIRED: 支持当前事务(外部事务),如果不存在则创建新事务.
// REQUIRES_NEW: 创建一个新事务,并且暂停当前事务(外部事务).
// NESTED: 如果当前存在事务(外部事务),则嵌套在该事务中执行(独立的提交和回滚),否则就会REQUIRED一样.
@Transactional(isolation = Isolation.READ_COMMITTED, propagation = Propagation.REQUIRED)
public Object save1() {
// 新增用户
User user = new User();
user.setUsername("alpha");
user.setSalt(CommunityUtil.generateUUID().substring(0, 5));
user.setPassword(CommunityUtil.md5("123" + user.getSalt()));
user.setEmail("[email protected]");
user.setHeaderUrl("http://image.nowcoder.com/head/99t.png");
user.setCreateTime(new Date());
userMapper.insertUser(user);
// 新增帖子
DiscussPost post = new DiscussPost();
post.setUserId(user.getId());
post.setTitle("Hello");
post.setContent("新人报道!");
post.setCreateTime(new Date());
discussPostMapper.insertDiscussPost(post);
Integer.valueOf("abc");
return "ok";
}编程式事务
public Object save2() {
transactionTemplate.setIsolationLevel(TransactionDefinition.ISOLATION_READ_COMMITTED);
transactionTemplate.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED);
return transactionTemplate.execute(new TransactionCallback<Object>() {
@Override
public Object doInTransaction(TransactionStatus status) {
// 新增用户
User user = new User();
user.setUsername("beta");
user.setSalt(CommunityUtil.generateUUID().substring(0, 5));
user.setPassword(CommunityUtil.md5("123" + user.getSalt()));
user.setEmail("[email protected]");
user.setHeaderUrl("http://image.nowcoder.com/head/999t.png");
user.setCreateTime(new Date());
userMapper.insertUser(user);
// 新增帖子
DiscussPost post = new DiscussPost();
post.setUserId(user.getId());
post.setTitle("你好");
post.setContent("我是新人!");
post.setCreateTime(new Date());
discussPostMapper.insertDiscussPost(post);
Integer.valueOf("abc");
return "ok";
}
});
}边栏推荐
猜你喜欢

General syntax and usage instructions of SQL (picture and text)

Binder机制(下篇)

Flink + sklearn - use JPMML implement flink deployment on machine learning model

win10系统更新错误代码0x80244022怎么办

FP6296锂电池升压 5V9V12V内置 MOS 大功率方案原理图

FP7195大功率零压差全程无频闪调光DC-DC恒流芯片(兼容调光器:PWM调光,无极调光,0/1-10V调光)

【STM32学习1】基础知识与概念明晰

What should I do if Windows 10 cannot connect to the printer?Solutions for not using the printer

推开机电的大门《电路》(三):说说不一样的电阻与电导

Open the door of power and electricity "Circuit" (2): Power Calculation and Judgment
随机推荐
实战美团Nuxt +Vue全家桶,服务端渲染,邮箱验证,passport鉴权服务,地图API引用,mongodb,redis等技术点
Win7怎么干净启动?如何只加载基本服务启动Win7系统
FP5139电池与适配器供电DC-DC隔离升降压电路反激电路电荷泵电路原理图
DP4301无线收发SUB-1G芯片兼容CC1101智能家居
win10 system update error code 0x80244022 how to do
pytorch模型转libtorch和onnx格式的通用代码
win10任务栏不合并图标如何设置
In-depth understanding of Golang's Map
专硕与学硕
基于矩阵计算的线性回归分析方程中系数的估计
Network Security Packet Capture
Publish module to NPM should be how to operate?Solutions to problems and mistake
轻量化AlphaPose
7. How to add the Click to RecyclerView and LongClick events
Article pygame drag the implementation of the method
HAL框架
Please make sure you have the correct access rights and the repository exists.问题解决
How to simulate 1/3 probability with coins, and arbitrary probability?
Win11怎么在右键菜单添加一键关机选项
Win11系统找不到dll文件怎么修复