MySQL事务、锁以及应用(一)

黄舟
发布: 2017-02-06 10:37:26
原创
1584人浏览过

一、事务是什么

事务是一条或多条数据库操作语句的组合,具备ACID四个特征:

  • 原子性(Atomicity)

要不全部成功,要不全部撤销。

  • 一致性( Consistency )

数据库正确地改变状态后,数据库的一致性约束没有被破坏。

  • 隔离性( Isolation )

事务之间相互独立,互不干扰。

  • 持续性( Durability )

事务的提交结果,将持久保存在数据库中。

二、事务并发会产生的问题

如果在没有事务隔离的情况下,可能出现:

  • 脏读

脏读是指当一个事务读取了一条数据,并对数据进行了修改,但是还没有提交,这时另外一个事务也读取了这条数据,然后使用了这条数据。如:用户的账户金额是100,T1将其修改为200,但是未提交,与此同时T2读取到用户账户金额是200,然后T1发生异常回滚,T2读到的200就是脏数据。

  • 不可重复读

不可重复读是指对于数据库某一条数据,一个事务内多次查询但是返回了不同的值,这是由于在查询间隔,被另一个事务修改并提交了。

AppMall应用商店
AppMall应用商店

AI应用商店,提供即时交付、按需付费的人工智能应用服务

AppMall应用商店 56
查看详情 AppMall应用商店
  • 幻读

在一个事务的两次查询中数据行数不一致。例如一个事务查询了几列数据,而另外一个事务在此时插入了新的几列数据,第一个事务在接下来的查询中会发现有几列数据是它之前没有的,就好像产生幻觉一样,这就是发生了幻读。

三、事务隔离级别

事务隔离级别解决了什么并发问题,还存在什么并发问题?

1、Read Uncommitted(读取未提交内容)

这是事务最低的隔离级别,它充许另外一个事务可以看到这个事务未提交的数据。对并发出现的任何问题都无法避免。

2、Read Committed(读取提交内容)

保证一个事务修改的数据提交后才能被另外一个事务读取,即另外一个事务不能读取该事务未提交的数据。可避免脏读的发生,但是会出现不可重复读、幻读。

3、Repeatable Read(可重读)

这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据。可避免脏读、不可重复读的发生,但是会出现幻读。

4、Serializable(可串行化)

这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突。在这个级别,可能导致大量的超时现象和锁竞争。可避免脏读、不可重复读、幻读的发生。

下一篇介绍InnoDB引擎的锁机制。

以上就是MySQL事务、锁以及应用(一)的内容,更多相关内容请关注PHP中文网(www.php.cn)!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号