# 事务四大特性(ACID) # 原子性(Atomicity):事务是不可分割的最小操作单元,要么全部成功,要么全部失败。 # 一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态。 # 隔离性(Isolation):数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行。 # 持久性(Durability):事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。 # 并发事务问题 # 脏读 一个事务读到另外一个事务还没有提交的数据。 -- 解读:事务A执行select 操作 再执行update操作,事务A再执行update操作会将数据库中数据更新,这时事务B进行select操作,就去读到事务A未提交的数据,称为脏读 # 不可重复读 一个事务先后读取同一条记录,但两次读取的数据不同,称之为不可重复读。 -- 解读:事务A进行select ,同时事务B进行update操作,且提交了,之后事务A再次进行select操作,这时事务A读取的两次记录不一样。称为不可重复读 # 幻读 -个事务按照条件查询数据时,没有对应的数据行,但是在插入数据时,又发现这行数据已经存在,好像出现了幻影”。 -- 解读:事务A先进行select操作发现没有,这时事务B在进行insert操作并提交,这时数据库中已经存在数据,之后事务A在进行insert操作便不能成功, -- 再不可重复读已经解决的情况下,事务A读不到其他事务提交的数据,但是数据已经存在,所以事务A进行select也不能查到,就出现了"幻读" # 事务隔离级别 # 隔离级别 脏读 不可重复读 幻读 # Read uncommitted √ √ √ # Read committed × √ √ # Repeatable Read(默认) × × √ # Serializable × × × # -查看事务隔离级别 # SELECT @@TRANSACTION_ISOLATION, SELECT @@TRANSACTION_ISOLATION; # 设置事务隔离级别 # SET [SESSION|GLOBAL] TRANSACTION ISOLATION LEVEL { READ UNCOMMITTED | READ COMMITED | REPEATABLE READ | SERIALIZABLE} set session transaction isolation level read uncommitted; set session transaction isolation level repeatable read ;
SQL基础篇-事务
于 2024-09-28 23:36:12 首次发布