SQL基础篇-事务

# 事务四大特性(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 ;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值