MySQL事务相关知识

事务: 
     由一条或多条sql语句组成的不可分割的单元,一旦事务处理失败,则返回某个状态。
     因此,事务要么全成功,要么全失败。

原子性:事务是一组不可分割的操作单元,这组单元要么同时成功要么同时失败;
一致性:事务前后的数据完整性要保持一致;
隔离性:多个用户的事务之间不要相互影响,要相互隔离);
持久性:一个事务一旦提交,那么它对数据库产生的影响就是永久的不可逆的,如果后面再回滚或者出异常,都不会影响已提交的事务

     
查看当前自动提交的方法:
select @@autocommit;    //1为开启自动提交,0为关闭自动提交;

操作步骤:
     1.  select @@autocommit; 
         set  autocommit =0 ;     //关闭自动提交
     2.  begin   或   start transaction      //开始事务(可不写)
     3.  sql语句
     4.  commit (关闭事务)

savepoint  point1;  设置一个名字为point1的保存点
rollback to point1;  事务回滚到保存点point1,而不是回滚到初始状态,    若没有保存点,则返回事务的初始位置;

多个事务同时操作时可能产生的问题:

  1. 脏读(Dirty Read):一个事务读取了另一个事务未提交的数据。例如当事务A和事务B并发执行时,当事务A更新后,事务B查询读取到A尚未提交的数据,此时事务A回滚,则事务B读到的数据就是无效的脏数据。(事务B读取了事务A尚未提交的数据)只要没有commit  或者 rollback 事务都不算结束    //即:通过返回使查询的数据无效化。
  2. 不可重复读(NonRepeatable Read): 一个事务的操作导致另一个事务前后两次读取到不同的数据。例如当事务A和事务B并发执行时,当事务B查询读取数据后,事务A更新操作更改事务B查询到的数据,此时事务B再次去读该数据,发现前后两次读的数据不一样。(事务B读取了事务A已提交的数据)  //即:通过更改数据使两次的数据不同。
  3. 虚读(PhantomRead)/幻读:一个事务的操作导致另一个事务前后两次查询的结果数据量不同。例如当事务A和事务B并发执行时,当事务B查询读取数据后,事务A新增或者删除了一条满足事务B查询条件的记录,此时事务B再去查询,发现查询到前一次不存在的记录,或者前一次查询的一些记录不见了。(事务B读取了事务A新增加的数据或者读不到事务A删除的数据)   //即:通过更改查询条件,使两次数据不同。

查看当前隔离级别的方法:
SELECT @@tx_isolation;


隔离级别:
第一种隔离级别:Read uncommitted(未提交读)
如果一个事务已经开始写数据,则另外一个事务不允许同时进行写操作,
但允许其他事务读此行数据,该隔离级别可以通过“排他写锁”,但是不排斥读线程实现。
这样就避免了更新丢失,却可能出现脏读,也就是说事务B读取到了事务A未提交的数据

解决了更新丢失,但还是可能会出现脏读

 

第二种隔离级别:Read committed(已提交读)
如果是一个读事务(线程),则允许其他事务读写,
如果是写事务将会禁止其他事务访问该行数据,该隔离级别避免了脏读,但是可能出现不可重复读。
事务A事先读取了数据,事务B紧接着更新了数据,并提交了事务,而事务A再次读取该数据时,数据已经发生了改变。

解决了更新丢失和脏读问题

 

第三种隔离级别:Repeatable read(可重复读)
可重复读取是指在一个事务内,多次读同一个数据,
在这个事务还没结束时,其他事务不能访问该数据(包括了读写),
这样就可以在同一个事务内两次读到的数据是一样的,
因此称为是可重复读隔离级别,读取数据的事务将会禁止写事务(但允许读事务),
写事务则禁止任何其他事务(包括了读写),这样避免了不可重复读和脏读,
但是有时可能会出现幻读。(读取数据的事务)可以通过“共享读镜”和“排他写锁”实现。

解决了更新丢失、脏读、不可重复读、但是还会出现幻读

 

第四种隔离级别:Serializable(串行化)
提供严格的事务隔离,它要求事务序列化执行,事务只能一个接着一个地执行,
但不能并发执行,如果仅仅通过“行级锁”是无法实现序列化的,
必须通过其他机制保证新插入的数据不会被执行查询操作的事务访问到。
序列化是最高的事务隔离级别,同时代价也是最高的,性能很低,一般很少使用,
在该级别下,事务顺序执行,不仅可以避免脏读、不可重复读,还避免了幻读

解决了更新丢失、脏读、不可重复读、幻读(虚读)

 

等级比较:

隔离级别    脏读    不可重复读   幻读
未提交读    可以    可以            可以
已提交读    不可以    可以         可以
可重复读    不可以    不可以      可以
串行化    不可以    不可以        不可以   效率最低


以上级别中,级别最高的是串行化,但是,级别越高,导致效率越低。

调整当前隔离级别:
set session transaction isolation level Read uncommitted;       //设置当前隔离级别为未提交读写;
即 set session transaction isolation level (+需要的隔离级别);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值