mysql之事务特性以及四种隔离级别

mysql之事务特性以及四种隔离级别

  • 事务
    • ACID特性
    • 启动事务
    • 结束事务
    • 自动提交
    • 事务支持保存点savepoint
  • 事务隔离级别
    • READ UNCOMMITTED
    • READ COMMITTED
    • REPEATABLE READ
    • SERIALIZABILE
    • 修改事务隔离级别
    • 死锁

事务

ACID特性

  • A:atomicity原子性;整个事务中的所有操作要么全部成功执行,要么全部失败后回滚
  • C:consistency一致性;数据库总是从一个一致性状态转换为另一个一致性状态
  • I:Isolation隔离性;一个事务所做出的操作在提交之前,是不能为其它事务所见;隔离有多种隔离级别,实现并发
  • D:durability持久性;一旦事务提交,其所做的修改会永久保存于数据库中

启动事务

BEGIN
BEGIN WORK
START TRANSACTION

结束事务

COMMIT:提交
ROLLBACK: 回滚

自动提交

set autocommit={1|0} 默认为1,为0时设为非自动提交
建议:显式请求和提交事务,而不要使用“自动提交”功能

事务支持保存点savepoint

SAVEPOINT c_save   --创建一个保存点,名字叫c_save
ROLLBACK [WORK] TO [SAVEPOINT] c_save  --把事务回滚到c_save的状态
RELEASE SAVEPOINT c_save   --删除保存点c_save

事务隔离级别

READ UNCOMMITTED

可读取到未提交数据,产生脏读

READ COMMITTED

可读取到提交数据,但未提交数据不可读,产生不可重复读,即可读取到多个提交数据,导致每次读取数据不一致

REPEATABLE READ

可重复读,多次读取数据都一致,产生幻读,即读取过程中,即使有其它提交的事务修改数据,仍只能读取到未修改前的旧数据。此为MySQL默认设置

SERIALIZABILE

可串行化,未提交的读事务阻塞修改事务,或者未提交的修改事务阻塞读事务。导致并发性能差

mysql之事务特性以及四种隔离级别_第1张图片

修改事务隔离级别

vim /etc/my.cnf
[mysqld]
transaction-isolation=SERIALIZABLE

死锁

两个或多个事务在同一资源相互占用,并请求锁定对方占用的资源的状态

你可能感兴趣的:(mysql之事务特性以及四种隔离级别)