当前位置:网站首页>5. Transaction management
5. Transaction management
2022-08-02 15:32:00 【Caviar :P】
1.事务特性
2.事务的隔离性
- 常见的并发异常
- 第一类丢失更新、第二类丢失更新.
- 脏读、不可重复读、幻读.
第一类丢失更新:某一个事务的回滚,导致另外一个事务已更新的数据丢失了.
第二类丢失更新:某一个事务的提交,导致另外一个事务已更新的数据丢失了.
脏读:某一个事务,读取了另外一个事务未提交的数据.
不可重复读:某一个事务,对同一个数据前后读取的结果不一致. (The result of querying a piece of data is inconsistent)
幻读:某一个事务,对同一个表前后查询到的行数不一致.(The results of querying multiple pieces of data are inconsistent)
- 常见的隔离级别
- Read Uncommitted:读取未提交的数据.
- Read Committed:读取已提交的数据.
- Repeatable Read:可重复读.
- Serializable:串行化.
3.实现机制
- 悲观锁(数据库)
- 共享锁(S锁)
事务A对某数据加了共享锁后,其他事务只能对该数据加共享锁,但不能加排他锁. - 排他锁(X锁)
事务A对某数据加了排他锁后,其他事务对该数据既不能加共享锁,也不能加排他锁.
- 共享锁(S锁)
- 乐观锁(自定义)
- 版本号、时间戳等
在更新数据前,检查版本号是否发生变化.若变化则取消本次更新,否则就更新数据(版本号+1).
- 版本号、时间戳等
4.Spring事务管理
No matter what the underlying database is,它的api都是一套
- 声明式事务
- 通过XML配置,声明某方法的事务特征.(This project uses this)
- 通过注解,声明某方法的事务特征.
- 编程式事务
- 通过 TransactionTemplate 管理事务,并通过它执行数据库的操作.
声明式事务
在 @Transactional The isolation mechanism and propagation mechanism are defined on the annotation.当save1()After an error occurs in the method,The whole method rolls back,插入数据库失败.
// 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 code for pytorch model to libtorch and onnx format
刷卡芯片CI520可直接PIN对PIN替换CV520支持SPI通讯接口
pygame image rotate continuously
What is Win10 God Mode for?How to enable God Mode in Windows 10?
cmake configure libtorch error Failed to compute shorthash for libnvrtc.so
7. How to add the Click to RecyclerView and LongClick events
项目:数据库表的梳理
Win10 cannot directly use photo viewer to open the picture
casbin模型
4.发布帖子,评论帖子
CMAKE
How to simulate 1/3 probability with coins, and arbitrary probability?
MATLAB绘制平面填充图入门详解
cmake配置libtorch报错Failed to compute shorthash for libnvrtc.so
MATLAB绘图命令fimplicit绘制隐函数图形入门详解
How to solve Win11 without local users and groups
深入理解Golang之Map
LORA芯片ASR6601支持M4内核的远距离传输芯片
Mysql连接错误解决
Mysql lock