ACID及事务隔离级别

2)ACID及事务隔离级别

ACID四大特性解释

  • 原子性(Atomicity):一个事务内的操作,要么全部成功,要么全部失败。
  • 一致性(Consistency):数据库从一个一致性状态,转移到另一个一致性状态。
  • 隔离性(Isolation):多个并发事务之间是隔离的。
  • 持久性(Durability):数据一旦提交,改变是永久的。

ACID靠什么保证

  • 原子性由undo log日志保证, 他记录了需要回滚的日志信息,事务回滚时撤销已经执行成功的sql;
  • 一致性由其他的三大特性来保证;
  • 隔离性由MVCC来保证;
  • 持久性由redo log保证。重做日志缓冲(redo log buffer)和重做日志(redo log)组成,前者在内存中,后者在磁盘中。redo log 用来记录已成功提交事务的修改信息,并且把redo log持久化到磁盘

事务

(1)事务:

是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,这些操作要么同时成功,要么同时失败。

(2)事务的控制:

MySQL中的事务默认自动提交,我们可以改成手动

sql 复制代码
-- 查看事务的提交方式
select @@autocommit;
set @@autocommit = 0; # 设置0为取消自动提交,1为开启自动提交
-- 开启事务
begin; | start transaction;
-- 提交事务
commit;
-- 回滚事务
rollback;

(3)事务的隔离级别

隔离级别 脏读 丢失修改 不可重复读 幻读
Read Uncommitted 读未提交 可以出现 可以出现 可以出现 可以出现
Read committed 读已提交(Oracle 默认) 不能出现 可以出现 可以出现 可以出现
Repeatable Read 可重复读(mysql 默认) 不能出现 不能出现 不能出现 可以出现
Serializable 可串行化 不能出现 不能出现 不能出现 不能出现

解释:从上到下安全性由低到高,性能由高到低

sql 复制代码
-- 查看事务的隔离级别
select @@transaction_isolation
-- 设置事务隔离级别 session是当前的会话,global是全局
set [session|global] transaction isolation level {隔离级别} 
相关推荐
Menior_17 分钟前
【补充】数据库中有关系统编码和校验规则的简述
数据库·mysql·oracle
晴子呀1 小时前
分库分表和sql的进阶用法总结
数据库·sql
编程(变成)小辣鸡1 小时前
Redis 知识点与应用场景
数据库·redis·缓存
Kay_Liang1 小时前
从聚合到透视:SQL 窗口函数的系统解读
大数据·数据库·sql·mysql·数据分析·窗口函数
H2122021651 小时前
SQLite3库链接与加载问题解决方案
数据库·oracle·sqlite
IT毕设实战小研1 小时前
基于Spring Boot校园二手交易平台系统设计与实现 二手交易系统 交易平台小程序
java·数据库·vue.js·spring boot·后端·小程序·课程设计
倔强的石头_1 小时前
KingbaseES高可用架构深度解析——从读写分离到异地灾备的全方位守护
数据库
范纹杉想快点毕业3 小时前
嵌入式 C 语言编程规范个人学习笔记,参考华为《C 语言编程规范》
linux·服务器·数据库·笔记·单片机·嵌入式硬件·fpga开发
诺亚凹凸曼3 小时前
MySQLinnodb引擎普通索引和唯一索引的区别
数据库·mysql
davawang4 小时前
程序自动化vs人工手动处理
数据库·数据分析·企业文化