数据库隔离级别详解[通俗易懂]

数据库隔离级别详解[通俗易懂]之前,我们有讲过数据库的索引,链接为数据库索引详解今天,我们将讲解数据库的隔离级别。一、隔离级别的种类与分别可以解决的问题:事务的隔离级别分为4个,即读未提交(readuncommitted)、读已提交(readcommitted)、可重复读(Repeatableread)、可串行化(Serializable)oracle默认的隔离级别为读已提交。mysql的默…

大家好,又见面了,我是你们的朋友全栈君。

  之前,我们有讲过数据库的索引,链接为 数据库索引详解 今天,我们将讲解数据库的隔离级别。

一、隔离级别的种类与分别可以解决的问题:

  事务的隔离级别分为4个,即 读未提交(read uncommitted)、读已提交(read committed)、可重复读(Repeatable read)、可串行化(Serializable)

 oracle默认的隔离级别为 读已提交。mysql的默认隔离级别为 可重复读。

 其中可以解决的问题如下表:

数据库隔离级别详解[通俗易懂]

  简单来说:

  脏读即为session A读取到了session B中未提交的数据

  不可重复读即为session A读取到了session B提交的数据,即前后session A读取的数据不一致

  幻读即为session A读取到了session B insert的数据。

 

二、隔离级别的设置与查询:

 1、设置隔离级别:

  设置隔离级别分为设置全局的隔离级别与设置当前的隔离级别

  全局设置,已存在的session不会生效,以后的新session会生效(以读未提交举例):

   set global transaction isolation level read uncommitted;

  单独设置当前连接:

    set session transaction isolation level read uncommitted;

 2 、查看当前隔离级别:

   select @tx_isolation;

 

三、事务隔离级别的测试:

有一个goods表,里面有id、count(商品数量)、brandId(品牌id)

CREATE TABLE `goods` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`count` int(11) DEFAULT '0',

`brandId` int(11) DEFAULT '0',

PRIMARY KEY (`id`),

KEY `idx_brandId` (`brandId`)

) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf-8;

1、脏读(设置隔离级别为读未提交):

  脏读为读到其它事务未提交的数据:

A B

select * from goods where id = 1;

返回1

 
  update goods set count = 2 where id = 1;

select * from goods where id = 1;

返回2

 
  commit;

2、不可重复读(设置隔离级别为 读已提交)

  不可重复读为读到其它数据已提交的数据,即前后查询数据不一致

A B

select * from goods where id = 1;

返回1

 
  update goods set count = 2 where id = 1;

select * from goods where id = 1;

返回1

 
  commit;

select * from goods where id = 1;

返回2

 

3、幻读(设置隔离级别为 可重复读):

  幻读为读到别人已提交的写入数据库的数据。

  幻读与不可重复读的区别为幻读为读到新插入的数据(insert),而不可重复读主要是更改与删除(update、delete)。

  即不可重复读前后被其它session update、delete的数据没有问题,不会有变化,但是其它session insert的可能有变化。

A B

select * from goods where brandId = 1;

返回有id为1,2的两条

 
  insert into goods (count,brandId) values (3, 1);
  commit;

select * from goods where brandId = 1;

返回有id为1,2,3的三条

 

当隔离级别为 可串行化 的时候则不会出现上述问题。

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/141226.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • GBDT算法原理以及实例理解[通俗易懂]

    GBDT算法原理以及实例理解[通俗易懂]【尊重原创,转载请注明出处】http://blog.csdn.net/zpalyq110/article/details/79527653  GBDT的全称是GradientBoostingDecisionTree,梯度下降树,在传统机器学习算法中,GBDT算的上TOP3的算法。想要理解GBDT的真正意义,那就必须理解GBDT中的GradientBoosting和Decision…

    2022年10月12日
  • inputstreamreader类是用于将_readstring

    inputstreamreader类是用于将_readstring一、InputStreamReader类InputStreamReader将字节流转换为字符流。是字节流通向字符流的桥梁。如果不指定字符集编码,该解码过程将使用平台默认的字符编码,如:GBK。构造方法:InputStreamReaderisr=newInputStreamReader(InputStreamin);//构造一个默认编码集的InputStr

  • Pytest(1)安装与入门[通俗易懂]

    Pytest(1)安装与入门[通俗易懂]pytest介绍pytest是python的一种单元测试框架,与python自带的unittest测试框架类似,但是比unittest框架使用起来更简洁,效率更高。根据pytest的官方网站介绍,它

  • 代理重加密_代理重加密BBS方案

    代理重加密_代理重加密BBS方案云计算中的数据机密性风险极大地阻碍了云计算的应用,而在用户端加密的模式对于数据共享来说非常不便,用户频繁的获取和释放授权将使得用户增效据加解密工作繁重。因此代理重加密技术在云端进行数据的密文转换,减轻了用户端的负担,同时加强了云端数据的保密性。一、代理重加密代理重加密是密文间的一种密钥转换机制,是由Blaze等人在1998年的欧洲密码学年会上提出的,并由Ateniese等人在2005年的网络和分布式系统安全研讨会议和2007年的美国计算机学会计算机与通信安全会议上给出了规范的形式化定义。在代理重加密中

  • DOS命令大全–具体解释

    DOS命令大全–具体解释

  • 服务器php环境搭建教程,PHP服务端环境搭建图文详解

    服务器php环境搭建教程,PHP服务端环境搭建图文详解PHP环境搭建也是一门技术,本文主要为大家分享一篇PHP服务端环境搭建的图文教程,具有很好的参考价值,希望对大家有所帮助。一、PHP服务端环境搭建1.php服务端环境安装套件xampp(apach+mysql+php解释器)F:\MyDoc文件(重要)\DL_学习\download重要资源\apache服务器组件安装此时进入xmapp面板显示成功运行测试本地Apache服务器是否开启:浏览器…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号