数据库并发控制、事务的隔离级别、由低到高分别为Read uncommitted读未提交、Read committed读提交、Repeatable read重复读、Serializable序列化数据库并发控制、事务的隔离级别、由低到高分别为Read uncommitted读未提交、Read committed读提交、Repeatable read重复读、Serializable序列化

本文涉及的产品
视频点播 VOD,流量+存储+转码
简介: 数据库并发控制、事务的隔离级别、由低到高分别为Read uncommitted读未提交、Read committed读提交、Repeatable read重复读、Serializable序列化

@[toc]

5.数据库并发控制

5.6 事务的隔离级别

  数据库事务的隔离级别有4种,由低到高分别为Read uncommitted 、Read committed 、Repeatable read 、Serializable。而且,在事务的并发操作中可能会出现脏读,不可重复读,幻读。

√:可能出现 ×:不会出现

脏读 不可重复读 幻读
Read uncommitted(读未提交)
Read committed(读提交) ×
Repeatable read(重复读) × ×
Serializable(序列化) × × ×

Serializable 性能最低,数据安全性最高;Read uncommitted 性能最高,数据安全性最差

-- 查看事务隔离级别
SELECT @@TRANSACTION_ISOLATION;

-- 设置事务隔离级别
-- SET [ SESSION | GLOBAL ] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE };
-- SESSION 是会话级别,表示只针对当前会话有效,GLOBAL 表示对所有会话有效
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;

5.6.1 Read uncommitted(读未提交)

  读未提交,就是一个事务可以读取另一个未提交事务的数据。
  事例:张三的工资是15k,这个月发工资,财务不小心按错了数字,还没有来得及提交事务,就在这个时候,张三发现的工资变为了19k,张三以为涨工资了高兴的飞起,财务发现不对,回滚了事务,将工资改回了15k万元再提交。
  分析:实际张三这个月的工资还是15k万,但是张三看到的是19k万。张三看到的是老板还没提交事务时的数据。这就是脏读。

时间 事务A 事务B
T1 开启事务 开启事务
T2 查询得到的值为15k 查询得到的值为15k
T3 将15k改为19k
T4 查询得到的值为19k
T5 将19k改为15k
T6 查询得到的值为15k
T7 提交事务B
T8 查询得到的值为15k
T9 提交事务A

[video(video-cs70T9nK-1662891357605)(type-csdn)(url-https://live.csdn.net/v/embed/238251)(image-https://video-community.csdnimg.cn/vod-84deb4/835fe6de5d2d4d9bbbdd0693b436f079/snapshots/095dbdf2b02b4058a5aad102ed6eb248-00005.jpg?auth_key=4816405984-0-0-25be0bad83644e20e75b835dce247ad3)(title-读未提交演示)]

5.6.2 Read committed(读提交)

  读提交,就是一个事务要等另一个事务提交后才能读取数据。
  事例:张三的工资是15k,这个月发工资,财务给张三涨工资,将张三的工资改为19k,还没有来得及提交事务,就在这个时候,张三查询他的工资时还是15k,张三以为不给他涨工资了有点失落,财务提交了事务,然后张三不相信没有给他涨工资,就又查了一遍,发现他的工资涨到了19k。
分析:如果有事务对数据进行更新(UPDATE)操作时,读取数据事务要等待这个更新操作事务提交后才能读取数据,有效的避免脏读,但是一个事务进行了两次相同的查询而返回了不同的数据,这就是不可重复读。

时间 事务A 事务B
T1 开始事务
T2 查询得到的值为15k 开始事务
T3 将15k改为19k
T4 事务提交
T5 查询得到的值为19k
T6 事务提交

[video(video-uqVzgogo-1662891892596)(type-csdn)(url-https://live.csdn.net/v/embed/238326)(image-https://video-community.csdnimg.cn/vod-84deb4/a75cbd4acc6c4e3d943796017f481474/snapshots/a8f528efc3464c55bf95425c7a55c7dc-00005.jpg?auth_key=4816489276-0-0-c512f6e39440de149d6024395f068172)(title-读提交,不可重复读)]

5.6.3 Repeatable read(重复读)

  重复读,就是在开始读取数据(事务开启)时,不再允许修改操作。
  事例:张三的工资是15k,这个月发工资,张三查询他的工资时是15k,财务给张三涨工资,将张三的工资改为19k,提交了事务,张三再次查询他的工资时还是15k,张三以为不给他涨工资了有点失落,提交了事务,然后张三不相信没有给他涨工资,就又查了一遍,发现他的工资涨到了19k。
  分析:重复读可以解决不可重复读问题。写到这里,应该明白的一点就是,不可重复读对应的是修改,即UPDATE操作。但是可能还会有幻读问题。因为幻读问题对应的是插入INSERT操作,而不是UPDATE操作。

5.6.3.1 可重复读

时间 事务A 事务B
T1 开始事务
T2 查询得到的值为15k 开始事务
T3 将值改为19k
T4 查询得到的值为15k
T5 提交事务
T6 查询得到的值为15k
T7 提交事务
T8 查询得到的值为19k

[video(video-E7CgrmL7-1662892376192)(type-csdn)(url-https://live.csdn.net/v/embed/238332)(image-https://video-community.csdnimg.cn/vod-84deb4/c412fae227b1448d89e2f6bc912094c5/snapshots/160d8cbdf8ae42fb873de3b25a33694c-00005.jpg?auth_key=4816491586-0-0-d3e8bc11b467f3ab95a4b00739dc6fa7)(title-可重复读)]

5.6.3.2 出现幻读

时间 事务A 事务B
T1 开始事务
T2 查询id为3的值是为空的 开始事务
T3 插入一行值,id为3
T4 提交事务
T5 查询id为3的值是为空的
T6 插入一行值,id为3,报错,有id为3的
T7 查询id为3的值是为空的
T8 提交事务

[video(video-1t2Ek53k-1662892354094)(type-csdn)(url-https://live.csdn.net/v/embed/238331)(image-https://video-community.csdnimg.cn/vod-84deb4/fb483f1670cc4746b6c91b13b2cd4cd2/snapshots/dd2bf239b99f4a9b86befed2e29a8120-00005.jpg?auth_key=4816491563-0-0-79d61f8ac1e9192c963ef54a7ff92dbb)(title-幻读)]

5.6.4 Serializable(序列化)

  Serializable是最高的事务隔离级别,在该级别下,事务串行化顺序执行,可以避免脏读、不可重复读与幻读。但是这种事务隔离级别效率低下,比较耗数据库性能,一般不使用。
  提醒:大多数数据库默认的事务隔离级别是Read committed(读提交),比如Sql Server , Oracle。Mysql的默认隔离级别是Repeatable read(重复读).

时间 事务A 事务B
T1 开始事务 开始事务
T2 插入一行值,id为4
T3 插入一行值,id为4,等待中,不能插入
T4 提交事务 显示不能插入,因为有id为4了
T5 提交事务
相关文章
|
18天前
|
SQL 存储 Java
数据库———事务及bug的解决
事务的一些概念,并发事务以及并发事务引起的bug,脏读,不可重复读,幻读,数据库中的隔离级别,事务的简单应用
|
2月前
|
SQL Oracle 关系型数据库
南大通用GBase 8s 数据库封锁与并发事务调度介绍
南大通用GBase 8s 数据库封锁与并发事务调度介绍
|
2月前
|
Java 数据库连接 数据库
如何构建高效稳定的Java数据库连接池,涵盖连接池配置、并发控制和异常处理等方面
本文介绍了如何构建高效稳定的Java数据库连接池,涵盖连接池配置、并发控制和异常处理等方面。通过合理配置初始连接数、最大连接数和空闲连接超时时间,确保系统性能和稳定性。文章还探讨了同步阻塞、异步回调和信号量等并发控制策略,并提供了异常处理的最佳实践。最后,给出了一个简单的连接池示例代码,并推荐使用成熟的连接池框架(如HikariCP、C3P0)以简化开发。
70 2
|
3月前
|
数据库
什么是数据库的事务隔离级别,有什么作用
【10月更文挑战第21】什么是数据库的事务隔离级别,有什么作用
30 3
|
3月前
|
存储 关系型数据库 数据挖掘
什么是数据库的事务隔离级别
【10月更文挑战第21】什么是数据库的事务隔离级别
46 1
|
3月前
|
存储 数据库 数据库管理
数据库事务安全性控制如何实现呢
【10月更文挑战第15天】数据库事务安全性控制如何实现呢
|
3月前
|
存储 数据库 数据库管理
什么是数据库事务安全性控制
【10月更文挑战第15天】什么是数据库事务安全性控制
|
3月前
|
供应链 数据库
数据库事务安全性控制有什么应用场景吗
【10月更文挑战第15天】数据库事务安全性控制有什么应用场景吗
|
3月前
|
存储 监控 关系型数据库
MySQL并发控制与管理:优化数据库性能的关键
【10月更文挑战第17天】MySQL并发控制与管理:优化数据库性能的关键
410 0
|
2月前
|
JSON 数据格式 索引
Python中序列化/反序列化JSON格式的数据
【11月更文挑战第4天】本文介绍了 Python 中使用 `json` 模块进行序列化和反序列化的操作。序列化是指将 Python 对象(如字典、列表)转换为 JSON 字符串,主要使用 `json.dumps` 方法。示例包括基本的字典和列表序列化,以及自定义类的序列化。反序列化则是将 JSON 字符串转换回 Python 对象,使用 `json.loads` 方法。文中还提供了具体的代码示例,展示了如何处理不同类型的 Python 对象。