mysql四种输入_mysql四种事务隔离级别

mysql事务并发问题

ACID什么的就不啰嗦了。mysql多个事务并发的时候,可能会出现如下问题:

1. 更新丢失

即两个事务同时更新某一条数据,后执行的更新操作会覆盖先执行的更新操作,导致先执行的更新结果丢失。

2. 脏读

即一个事务会读到另一个事务尚未提交的数据更新,由于该数据更新可能会回滚,所以称之为脏读。

3. 不可重复读

即一个事务中对同一行数据读取两次,会得到不同的结果。原因是在该事务两次读取之间,其他事务会修改此数据。

4. 幻读

即一个事务对同一个表执行两次查询,会得到相同的结果行数。即使在该事务两次查询之间,其他事务同时也向此表插入了新的数据。

mysql事务隔离级别

mysql共支持四种事务隔离级别,分别是:

read uncommitted(读取未提交数据):从字面上理解,该事务隔离级别允许读取未提交数据。仅处理更新丢失的问题,但是不处理脏读、不可重复读、幻读的问题。

read committed(读取已提交数据):从字面上理解,该事务隔离级别允许读取已经提交的数据,即未提交的数据不可读取。则该事务隔离级别处理更新丢失、脏读的问题,不处理不可重复读、幻读的问题。

repeatable read(重复读):该事务隔离级别无法从字面上理解了,处理更新丢失、脏读、不可重复读的问题,不处理幻读的问题。

serializable(最高隔离级别):该事务隔离级别为最高事务隔离级别,处理以上所有问题,包括:更新丢失、脏读、不可重复读、幻读。

以上四种事务隔离级别依次递增,事务隔离级别越高,一致性越强可用性越差。

可以看到,所有的事务隔离界别都会处理更新丢失的问题。mysql默认的事务隔离级别为:repeatable read,即默认不处理幻读的问题。

废话不多说,直接上例子(大前提:数据库引擎为innoDB):

1. 首先要注意:mysql自动提交事务要关闭

查看mysql的autoCommit是否开启:

--查看mysql是否自动提交事务

show variables like 'autocommit';

如果需要关闭autoCommit,则执行如下语句:

--关闭autoCommit

set autocommit = 0;

2. 查看、设定mysql的事务隔离级别:注意只在当前会话session有效。

--查看当前数据库事务隔离级别

select @@tx_isolation;--设定当前数据库隔离级别为 read uncommitted

set session transaction isolation level read uncommitted;---set session transaction isolation level read committed ;--set session transaction isolation level repeatable read ;--set session transaction isolation level serializable;

3. 创建测试表及测试数据

usetest;create tabledt_table1 (

idint auto_increment primary key,

valuevarchar(50) null);insert into dt_table1 (value) value ('00000000');insert into dt_table1 (value) value ('00000000');insert into dt_table1 (value) value ('00000000');

(1)测试更新丢失

我们先更新一下数据,以便后续测试。

update dt_table1 set value = '00000000' where id = 1;

设定测试环境:创建两个session连接,并设定事务隔离级别 read uncommited

set session transaction isolation level read uncommitted;

打开session连接1,执行如下脚本,通过第三步可以看到数据已经被更新:

start transaction; --第一步

update dt_table1 set value = 'update 1' where id = 1; --第二步

select * from dt_table1 where id = 1; --第三步

打开session连接2,执行如下脚本,当执行第五步的时候,可以看到该更新操作被阻塞了。

start transaction; --第四步

update dt_table1 set value = 'update 2' where id = 1; --第五步

回到session连接1,执行commit,可以看到session连接2中第五步的更新操作也取消了阻塞并执行通过了。

commit; --第六步

回到session连接2,执行查询并commit。最终数据被更新为值‘update 2’。

select * from dt_table1 where id = 1; --第七步

commit; --第八步

通过以上的例子,我们可以看出,即使是mysql的最低事务隔离级别,也解决了更新丢失的问题。即:在session连接1中执行更新操作但尚未提交事务,session连接2中的更新操作会被阻塞,以避免session连接1中的更新丢失。将两个session连接的事务隔离级别设定为其他等级也会得到同样的结果。

(2)测试脏读

我们先更新一下数据,以便后续测试。

update dt_table1 set value = '00000000' where id = 1;

设定测试环境:创建两个session连接,并设定事务隔离级别 read uncommited。在此事务隔离级别下,会出现脏读的问题。

set session transaction isolation level read uncommitted;

打开session连接1,执行如下脚本。

start transaction; --第一步

update dt_table1 set value = 'read uncommitted' where id = 1; --第二步

打开session连接2,执行如下脚本。可以看到读取到了session连接1中已经更新但尚未提交的数据(查询值为‘read uncommited’)。

select * from dt_table1 where id = 1; --第三步

回到session连接1,执行rollback。

rollback; --第四步

回到session连接2,再次执行查询,可以看到查询值已经成功回滚(查询值为:‘00000000’)

select * from dt_table1 where id = 1; --第五步

通过以上的例子,我们可以看出,将mysql的事务隔离级别设定为read uncommited,会出现脏读的问题。即:session连接2中在第三步会读取到session连接1中已经更新但尚未提交的数据,由于session链接1可能会发生事务回滚,那么session连接2中读取到的数据也就无效了,即读取脏数据,即脏读。

如果设定事务隔离级别为read commited或以上,则不会出现此问题。上例中第三步读取到的值会为:'00000000'。即不会脏读。

(3)尝试不可重复读

我们先更新一下数据,以便后续测试。

update dt_table1 set value = '00000000' where id = 1;

设定测试环境:创建两个session连接,并设定事务隔离级别 read commited。在此事务隔离级别下,会出现不可重复读情况。

set session transaction isolation level read committed;

打开session连接1,执行如下脚本。可以看到查询值为‘00000000’

start transaction; --第一步

select * from dt_table1 where id = 1; --第二步

打开session连接2,执行如下脚本。

start transaction; --第三步

update dt_table1 set value = 'read committed' where id = 1; --第四步

commit; --第五步

回到session连接1,执行如下脚本。可以看到查询值为‘read commited’

select * from dt_table1 where id = 1; --第六步

commit; --第七步

通过以上的例子,我们可以看出,将mysql的事务隔离级别设定为read commited,会出现不可重复读问题,即在session连接1中的一个事务中,先后两次读取到的值不一样。原因是在该事务两次读取之间,session连接2的事务修改并提交了此数据。

如果设定事务隔离级别为repeatable read或以上,则不会出现此问题。上例中第六步读取到的数据值依然为‘00000000’

(4)尝试幻读

设定测试环境:创建两个session连接,并设定事务隔离级别 repeatable read。在此事务隔离级别下,会出现幻读的情况。

set session transaction isolation level repeatable read ;

我们先更新一下数据,以便后续测试

update dt_table1 set value = '00000000' where 1=1;

打开session连接1,执行如下脚本。我们记录下第二步查询结果行数,假如为n行。

start transaction; --第一步

select * from dt_table1; --第二步

打开session连接2,执行如下脚本。

start transaction; --第三步

insert into dt_table1 (value) value ('phantom read new'); --第四步

commit; --第五步

回到session连接1,执行如下脚本,可以看到第六步查询结果行数依然为n,但是执行第七步更新操作的时候,更新影响行数却是n+1。执行第九步查询的时候结果行数也是n+1

select * from dt_table1; --第六步

update dt_table1 set value = 'phantom read' where 1=1; --第七步

commit; --第八步

select * from dt_table1; --第九步

通过以上的例子,我们可以看出幻读问题的存在,即:第六步查询结果明明是n行,但是第七步跟新操作影响行数却是n+1,难道是我的幻觉?这就是幻读。

如果设定事务隔离级别为serializable,则不会出现此问题。第四步执行输入插入操作时会被阻塞,第七步更新操作影响结果行数和第六步查询结果行数也会保持一致,且执行到第九步的时候,可以看到第四步新插入的数据也并没有被第七步更新掉。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/350045.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

apache hadoop_春天遇见Apache Hadoop

apache hadoopSpringSource 刚刚宣布了适用于Apache Hadoop的Spring的第一个GA版本 。 该项目的目的是简化基于Hadoop的应用程序的开发。 您可以下载该项目在这里 ,并检查了Maven的文物在这里 。 Apache Hadoop的Spring诞生是为了解决Hadoop应用程序构建不良的问题…

sinacloud webpy mysql_Mysqldb和webpy的安装

1.首先安装mysqlsudo apt-get install mysql-server2.然后安装libmysqld-dev和libmysqlclient-dev,否则在安装Mysqldb的时候会报找不到mysql_config文件sudo apt-get install libmysqld-devsudo apt-get install libmysqlclient-dev修改site.cfg中的mysql_config的配…

消费者驱动的Pact和Spring Boot测试

最近,我的一位同事偶然发现了Pact.io ,我们的当前应用程序已发展到50多种服务,并且我们开始出现一些集成测试失败和脆弱的开发/验收测试环境。 因此,我们决定研究尝试与此相关的方法。 我从阅读开始: https : //docs.…

python空格怎么加密_使用Python的RSA加密

如果您想使用python高效地编码RSA加密,我的github存储库肯定会理解和解释python中RSA的数学定义RSA密钥生成def keyGen(): Generate Keypair i_prandint(0,20)i_qrandint(0,20)# Instead of Asking the user for the prime Number which in case is not feasible,# …

MySQL中字符串函数详细介绍

MySQL字符串函数对于针对字符串位置的操作,第一个位置被标记为1。 ASCII(str)返回字符串str的 最左面字符的ASCII代码值。如果str是空字符串, 返回0。如果str是NULL,返回NULL。 mysql> select ASCII(2);-> 50mysql> select ASCII(2)…

java 转储快照分析_分析Java核心转储

java 转储快照分析在本文中,我将向您展示如何调试Java核心文件,以查看导致JVM崩溃的原因。 我将使用在上一篇文章: 生成Java Core Dump中生成的核心文件。 您可以通过以下几种方法来诊断JVM崩溃: hs_err_pid日志文件 当JVM中发生…

zbox mysql_20190213云服务器部署禅道

1.系统环境:腾讯云服务器;Centos 7.02.工具:禅道的压缩包(需要是tar.gz文件名的)、Xshell、Xftp;3.安全组规则的设置;4.端口号的设置以下为详细步骤:需要在空白的服务器上去进行操作。还需要再琢磨的。1、x…

Java编程语言的历史和未来

通过AppDynamics解决应用程序问题的速度提高了10倍–以最小的开销在代码级深度监视生产应用程序。 开始免费试用! 作为Internet上著名的编程语言 ,Java对人们如何浏览数字世界产生了深远的影响。 Java功能设置了用户对他们访问互联网的设备的性能期望的…

fmdb和mysql的区别_FMDB

什么是数据库数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,我们可以很方便的对数据库中的数据进行增、删、改、查操作数据库类型数据库可以分为2大种类关系型数据库(主流)关系型数据库(主流)对象型数据库常用关系型数据库PC端:Oracle、MySQL、SQL S…

RabbiqMQ快速入门

RabbitMQ 官网地址: https://www.rabbitmq.com/ 一个遵循AMQP协议,开源面向消息的中间件,支持多种编程语言。 Rabbitmq 能做什么? 逻辑解耦,异步的消息任务消息持久化,重启不影响削峰,大规模的消息处理主要的特点 可靠性&#xf…

Java命令行界面(第13部分):JArgs

JArgs 1.0的区别在于,这是我的第13篇文章的主题,该文章是关于Java命令行参数解析的。 JArgs是一个开放源代码( BSD许可证 )库,主要由Steve Purcell和Ewan Mellor等 不同的贡献者支持。 事实证明,这在第一次…

pthread vs openMP之我见

前两天看了些并行计算的文章,了解了一些并行计算的方法和原理。然后发现多线程实现里面还有个openMP,这个以前从来没见过(火星了),之前只是知道pthread线程库和微软也实现了一套线程。又看了看openMP的一些教程才知道它…

线程池默认多少个线程_我需要多少个线程?

线程池默认多少个线程这取决于您的应用程序。 但是,对于那些希望对如何从生产站点购买的所有昂贵内核中挤出大量资金的人,请多多包涵,我将阐明围绕多线程 Java应用程序的奥秘。 内容针对最典型的Java EE应用程序进行了“优化”,该…

mysql error writing_MySQL:Error writing file (Errcode: 28)解决方法

问题描述:在执行创建表语句时提示:mysql> CREATE TABLE cash_request (id int(11) NOT NULL auto_increment,dev_id int(11) NOT NULL,bank_account_info varchar(255) NOT NULL,money int(11) NOT NULL,status tinyint(1) NOT NULL default 1,is_fan…

[暑假集训Day4T3]曲线

三分模板。 三分法求单峰函数最优值,之后每次取所有二次函数最优值即可 #pragma GCC optimize(3,"Ofast","inline") #include<iostream> #include<cstdio> #define N 100005 #define eps 1e-9 using namespace std; int read() {int x0,f1;cha…

模拟Spring Security上下文进行单元测试

今天&#xff0c;在为一种Java方法编写单元测试用例时&#xff0c;如下所示&#xff1a; public ApplicationUser getApplicationUser() {ApplicationUser applicationUser (ApplicationUser) SecurityContextHolder.getContext().getAuthentication().getPrincipal();return…

mysql semi-synchronous_MySQL Semisynchronous Replication介绍

前言MySQL 5.5版本之前默认的复制是异步(Asynchronous )模式的, MySQL 5.5 以plugins的方式提供了Semisynchronous Replication 模式。在介绍 semi sync 之前,我们先了解&#xff1a;半同步 Asynchronous 和 同步 Synchronous 。异步复制模式主库将已经提交的事务event 写入bin…

Jquery屏蔽回车键

1 $(function(){2 3 $(“#tagForm input”).keypress(4 5 function(event){6 7 if(event.keyCode 13){8 9 returnfalse;10 11 }12 13 });14 15 })转载于:https://www.cnblogs.com/pfs1314/archive/2011/04/19/2020706.html

滑坡泥石流的防御措施_滑坡泥石流防御

什么是滑坡、泥石流?滑坡是指山坡在河流冲刷、降雨、地震、人工切坡等因素影响下&#xff0c;土层或岩层整体或分散地顺斜坡向下滑动的现象。滑坡也叫地滑&#xff0c;群众中还有“走山”、“垮山”或“山剥皮”等俗称。泥石流是指在降水、溃坝或冰雪融化形成的地面流水作用下…

Event Delegate(代理)异常:该委托必须有一个目标 解决方法

正文待叙转载于:https://www.cnblogs.com/kodong/archive/2013/04/19/3031212.html