MySQL——事务ACID原则、脏读、不可重复读、幻读

什么是事务

要么都成功,要么都失败

一一一一一一一

  1. SQL执行:A给B转账 A 1000 ---->200 B 200

  2. SQL执行:B收到A的钱 A 800 B 400

一一一一一一一

将一组SQL放在一个批次中去执行~

事务原则:ACID原则(原子性、一致性、隔离性、持久性)(脏读、幻读)

博客参考链接:https://blog.csdn.net/dengjili/article/details/82468576?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522171992206416800188587906%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=171992206416800188587906&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~baidu_landing_v2~default-6-82468576-null-null.142^v100^pc_search_result_base6&utm_term=acid&spm=1018.2226.3001.4187https://blog.csdn.net/dengjili/article/details/82468576?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522171992206416800188587906%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=171992206416800188587906&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~baidu_landing_v2~default-6-82468576-null-null.142^v100^pc_search_result_base6&utm_term=acid&spm=1018.2226.3001.4187

**原子性(Atomicity):**要么都成功,要么都失败

**一致性(Consistency):**事务前后的数据完整性要保持一致

**隔离性(Isolation):**事务的隔离性是多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。

**持久性(Durability):**事务一旦提交就不可逆转,被持久化到数据库中


隔离所导致的一些问题:

**1. 脏读:**指一个事务读取了另外一个事务未提交的数据。

**2. 不可重复读:**在一个事务内读取表中的某一行数据,多次读取结果不同。(这个不一定是错误,只是某些场合不对)

**3. 幻读:**是指在一个事务内读取到了别的事务插入的数据,导致前后读取数量总量不一致。

相关推荐
迷茫的21世纪的新轻年21 小时前
PostgreSQL——SQL优化
数据库·sql·postgresql
编程修仙21 小时前
第十一篇 Spring事务
xml·java·数据库·spring
绝顶少年21 小时前
Redis 高可用架构三部曲:主从复制、哨兵模式与集群模式深度解析
数据库·redis·架构
倔强的石头10621 小时前
从 Oracle 到 KingbaseES:破解迁移痛点,解锁信创时代数据库新可能
数据库·oracle·金仓数据库
2301_8002561121 小时前
8.3 查询优化 核心知识点总结
大数据·数据库·人工智能·sql·postgresql
三七吃山漆1 天前
攻防世界——supersqli
数据库·网络安全·web·ctf
零日失眠者1 天前
【Oracle入门到删库跑路-08】核心技能:用户和权限管理
数据库·oracle
7哥♡ۣۖᝰꫛꫀꪝۣℋ1 天前
Spring IoC&DI
java·开发语言·mysql
我科绝伦(Huanhuan Zhou)1 天前
Oracle控制文件、SCN与检查点机制深度解析及数据库初始化原理
运维·数据库·oracle
cui_win1 天前
MySQL max_connections连接数配置没生效,最终靠改这个参数解决
数据库·mysql