• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 详细介绍MySQL数据库事务隔离级别

详细介绍MySQL数据库事务隔离级别

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了MySQL,事务隔离等相关知识,希望本文的分享对您有所帮助
这篇文章主要介绍了MySQL数据库事务隔离级别详解的相关资料,需要的朋友可以参考下

数据库事务隔离级别

数据库事务的隔离级别有4个,由低到高依次为

  1. Read uncommitted:允许脏读。

  2. Read committed: 防止脏读,最常用的隔离级别,并且是大多数数据库的默认隔离级别。

  3. Repeatable read:可以防止脏读和不可重复读。

  4. Serializable:可以防止脏读,不可重复读取和幻读,(事务串行化)会降低数据库的效率。

这四个级别可以逐个解决脏读 、不可重复读 、幻读 这几类问题。

√: 可能出现 ×: 不会出现

事务级别脏读不可重复读幻读
Read uncommitted√√√
Read committed×√√
Repeatable read××√
Serializable×××

注意:我们讨论隔离级别的场景,主要是在多个事务并发的情况下。

脏读、幻读、不可重复读

脏读:

脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。

不可重复读:

是指在一个事务内,多次读同一数据。在这个事务还没有结束时,另外一个事务也访问该同一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的的数据可能是不一样的。这样就发生了在一个事务内两次读到的数据是不一样的,因此称为是不可重复读。(即不能读到相同的数据内容)

幻读:

是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样。

example:

表:

CREATE TABLE `cc_wsyw126_user_test_isolation_copy` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `password` varchar(64) NOT NULL,
 `age` int(11) NOT NULL,
 PRIMARY KEY (`id`),
 KEY `ix_age` (`age`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

模拟数据:

INSERT INTO `cc_wsyw126_user_test_isolation_copy` (`password`, `age`) 
VALUES 
('1', 1),
('2', 2),
('3', 3),
('4', 4);

第一个事务A:

start transaction 
insert into cc_wsyw126_user_test_isolation_copy (password, age) values ('5',5)
commit

第二个事务B:

start transaction 
update cc_wsyw126_user_test_isolation_copy set age = 2 where password >='2'
select * from cc_wsyw126_user_test_isolation_copy where password >= '2';
commit

重现步骤:

只要A事务的insert语句,在B事务select之前和update之后即可。

MySQL InnoDB存储引擎,实现的是基于多版本的并发控制协议——MVCC (Multi-Version Concurrency Control) 加上间隙锁(next-key locking)策略在Repeatable Read (RR)隔离级别下不存在幻读。如果测试幻读,在MyISAM下实验。

在聚集索引(主键索引)中,如果有唯一性约束,InnoDB会将默认的next-key lock降级为record lock。

以上就是详细介绍MySQL数据库事务隔离级别的详细内容,更多请关注微课江湖其它相关文章!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2018-12-05深入了解优化SQL查询-如何写出高性能SQL语句的具体分析
  • 2018-12-05MySQL 数据库优化的具体方法说明
  • 2018-12-05索引是什么?MySQL如何创建索引
  • 2018-12-05mysql数据库使用Node.js实现连接功能的示例
  • 2018-12-05使用BULK INSERT大批量导入数据 SQLSERVER
  • 2018-12-05浅析Oracle 11g中对数据列默认值变化的优化
  • 2017-05-11MySql修改数据库编码为UTF8避免造成乱码问题
  • 2018-12-05mysql其他函数
  • 2018-12-05最全mysql命令
  • 2018-12-05oracle 分页问题解决方案

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • php实现后期静态绑定
    • MySQL-Python安装问题小记
    • apache中访问不了伪静态页面的解决方法
    • MySQL数据库输入密码后闪退怎么办
    • MySQL数据类型中DECIMAL的用法实例详解
    • mysql 函数之Cast函数和操作符
    • mysql error:#1062 Duplicate entry ‘***′ for key 1问题解决
    • MySQL数据库备份工具Mydumper使用介绍
    • MYSQL使用inner join 进行 查询/删除/修改示例
    • mysql 协议的退出命令包及解析代码介绍

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有