MySQL事务的基础学习以及心得分享

63次阅读
没有评论

共计 2336 个字符,预计需要花费 6 分钟才能阅读完成。

这篇文章主要介绍了 MySQL 事务的基础学习以及心得分享,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让丸趣 TV 小编带着大家一起了解一下。

事务是逻辑上的一组操作,组成这组操作的各个单元,要不全都成功要不全都失败,这个特性就是事务,下面就是关于 MySQL 事务学习中的心得分享:

事务的特性

1. 原子性(Atomicity):原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。 

2. 一致性(Consistency):在一个事务中,事务前后数据的完整性必须保持一致,可以想象银行转账、火车购票。

3. 隔离性(Isolation):多个事务,事务的隔离性是指多个用户并发访问数据库时,一个用户的事务不能被其它用户的事务所干扰,多个并发事务之间数据要相互隔离。

4. 持久性(Durability):持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。

写这些概念呢,是有点绕!绕就绕吧!反正也不是我规定的,这是官方的,解释是我编的!!!

事务的并发访问问题

如果我们在不考虑隔离性问题时,事务是存在三种并发访问问题的。

1. 脏读:在一个事务中,当读取数据时,读到了另一个事务未提交的数据。 

比如 A 账户给 B 账户转了 1 块钱,但是 A 没有提交事务,被 B 账户通过脏读看到了,这时,B 就会以为 A 已经把钱转过来了,但是这时,A 账户回滚事务。其实钱就没给 B 转过去,但是 B 自己本身以为 A 已经转过去了,,,有点绕,估计是我描述到绕!

看代码:

update account set money=money+1 where name= B  -- 此时 A 去通知 B
update account set money=money -1 where name= A

2. 不可重复读:在一个事务中,两次读取的数据内容不一致,这是因为在查询时,有时间间隔,数据被另一个事务已经修改提交了,那就会出现问题。

3. 幻读 / 虚读:在一个事务中,两次读取的数据量不一致。

事务的隔离级别

上面介绍了 3 种事务并发问题!现在介绍一下数据库提供的解决方案!

1.read uncommitted : 读取尚未提交的数据:这个最低级,但是效率肯定最高,但是哪一个问题都不能解决。

2.read committed:读取已经提交的数据:可以解决脏读  。

3.repeatable read:重读读取:可以解决脏读 和 不可重复读。

4.serializable:串行化:可以解决脏读不可重复读和虚读, 效率最差,相当于锁表,开发中一般不用。 

上面的“2”是 oracle 数据库默认设置,“3”是 mysql 数据库默认的设置。

下面呢我就重点解释一下 mysql 数据库在上面各种事务隔离级别上的演示:

首先介绍两个语法:

1. 查看 mysql 数据库默认的隔离级别:select @@tx_isolation

如图:

2. 设置 mysql 的隔离级别:set session transaction isolation level 事务的隔离级别

如图:

事务的隔离级别演示

注意:如果要自己模拟要开启两个 mysql 客户端,也就是模拟两个用户!

1.read uncommitted

如图:

我通过语法将数据库的事务隔离级别改为了 read uncommitted。

首先我有一张 account 表。 

如图:窗口一

  窗口二

数据库表原始数据 money 都是 5000,当我启动事务后,在 zhangsan 账户增加了 1000 和在李四账户减去了 1000,但是我的事务还未提交,但是我再次查询数据库表时,数据已经发生变化,这就是脏读和不可重复读!

幻读 / 虚读我就不掩饰了,同样存在!

2.read committed

  如图:

我将数据库事务隔离性改为了 read committted。

还是上面那张表:

如图:窗口一

  窗口二

 

数据库表 zhangsan 账户的 money 和 lisi 账户的 money 都发生了变化,我未提交事务,在另一个窗口事务开启下查询时,没有出现脏读,但是当我提交事务时,在另一个窗口的事务下再次查询,出现了不可重复读的情况,这样可以避免脏读,但是查询时已经出现不可重复读和幻读 / 虚读!

3.repeatable read

如图:

我将数据库事务隔离性改为了 read committted。

还是上面那张表:

如图:窗口一

  窗口二

MySQL 事务的基础学习以及心得分享

我在两个窗口都开启了事务,当窗口一进行数据操作后,并进行事务提交,在窗口二的事务开启情况下,我去查询,没有查询到刚才窗口一的数据操作记录,这样就避免了脏读和不可重复读。

  有人说也避免了虚读 / 幻读,其实没有。

  看图:

MySQL 事务的基础学习以及心得分享

我在操作 lisi 账户时,数据只是发生修改的变化,但是当我修改 wangwu 这个账户时,再去查询出现了 wangwu,账户的数据,但是其实在我未操作前,wangwu 账户的数据是查询不出的。这就是幻读 / 虚读!

如果不理解幻读 / 虚读这块,可以查一下 InnoDB。

4.serializable

我就不演示了,开发不建议用,效率又慢,但是所有的问题都能避免!!

总结一下  

事务隔离级别的性能:

read uncommitted read committed repeatable read serialazable

事务隔离级别的安全性:

read uncommitted read committed repeatable read serialazable

mysql 事务控制:

开启事务:start transaction;

提交:commit;

回滚:rollback;

感谢你能够认真阅读完这篇文章,希望丸趣 TV 小编分享的“MySQL 事务的基础学习以及心得分享”这篇文章对大家有帮助,同时也希望大家多多支持丸趣 TV,关注丸趣 TV 行业资讯频道,更多相关知识等着你来学习!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-04发表,共计2336字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)