MySQL事务及隔离级别(读书小结)
标签: MySQL事务 隔离
0.什么是事务?
事务是指MySQL的一些操作看做是一个不可分割的执行单元。事务的特点是要么所有操作都执行成功,要么一个都不执行。也就是如果一个事务有操作执行失败,那么就会撤销该事物之前的所有操作,使数据库回到事务开始前的状态,此时就像什么事也没发生过一样。
1.事务的ACID特性
- 原子性Atomicity:事务的所有操作是一个不可分割的整体,要么都完成,要么都不做。
- 一致性Consistency:数据库保持从一个一致的状态到另一个一致的状态。如果一个事务执行了一部分,操作已经写入到物理数据库,此时发生了系统故障导致事务中断,但事务对数据库的修改又不可撤销了,此时数据库就处于一个不一致的状态。
- 隔离性Isolation:事务的操作是相互隔离,互不干扰的。(但是结果会有影响,如可看到其他事务操作的结果)
- 持久性Durability:事务的执行结果一旦完成就会对数据库造成永久改变,接下来的操作或故障不会对其有任何影响。
2.事务间可能出现的问题
- 脏读:一个事务读取到另一个事务的操作结果,但另一个事务之后又回滚撤销了,导致读取的结果有不存在的情况。
- 不可重复读:两次select结果不同。一个事务内的其他实例做了更新,一个实例在更新前后两次查询结果不同。
- 幻读:两次select结果不同。一个事务查询之后,另一个事务做了插入操作,此时这个事务再查询发现比第一次查询多了一些行,两次查询结果不同。
3.四种事务隔离级别
- Read Uncommitted(读未提交):本事务可以读取其他事务未提交的结果。会导致脏读、不可重复读、幻读。
- Read committed(读已提交):本事务只能读取其他事务提交后的结果。会导致不可重复读、幻读。
- Repeatable Read(可重复读):保证同一事务的多个实例读取到相同的结果。会导致幻读。InnoDB使用多版本并发机制(MVCC)解决该问题。
- Serializable(可串行化):在数据上加锁,锁定数据,使事务之间不可能发生冲突。会导致事务大量超时和锁竞争。让事务之间完全的隔离。不会导致事务之间出现的问题。
上面四种隔离程度依次是由低到高,处理并发效率由高到低。
4.MySQL选取隔离级别命令
用SET TRANSACTION语句改变单个会话或者所有新进连接的隔离级别。
语法如下:
SET [SESSION | GLOBAL] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE}
注意:默认的行为(不带session和global)是为下一个(未开始)事务设置隔离级别。
使用GLOBAL在全局对从开始创建的所有新连接设置事务级别。需要最高权限。
使用SESSION在当前连接上执行的事务设置事务级别。 任何客户端都能自由改变会话隔离级别(甚至在事务的中间),或者为下一个事务设置隔离级别。
查询全局和会话事务隔离级别:
SELECT @@global.tx_isolation;
SELECT @@session.tx_isolation;
SELECT @@tx_isolation;
5.总结
- 在低级别隔离,当多个事务并发执行时会导致多种问题,但是并发性好,可高效执行多个事务。
- 在高级别隔离,多个事务并发执行不会导致太多问题,但并发性差,执行多个事务效率低下。
- MySQL的InnoDB默认隔离是Repeatable Read(可重复读),oracle等多数数据库使用Read Committed(读已提交)。
- 实际中,在会计、银行、证券公司、股票等需要使用高安全性之外,为了兼顾并发性能其他要求相对低的应用可以使用级别较低的隔离。具体使用哪个,还是要由项目的需求决定。
参考:
http://www.linuxidc.com/Linux/2017-02/140848.htm
http://www.3lian.com/edu/2014/05-05/145482.html
http://blog.itpub.net/195110/viewspace-1080777/
http://www.cnblogs.com/tekkaman/p/5150663.html
MySQL事务及隔离级别(读书小结)的更多相关文章
- MySQL事务学习-->隔离级别
MySQL事务学习-->隔离级别 6 事务的隔离级别 设置的目的 在数据库操作中,为了有效保证并发读取数据的正确性,提出的事务隔离级别. 数据库是要被广大客户所共享访问的,那么在数据库操作过程中 ...
- MySQL事务及隔离级别详解
MySQL事务及隔离级别详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL的基本架构 MySQL的基本架构可以分为三块,即连接池,核心功能层,存储引擎层. 1> ...
- MySql事务及隔离级别
在数据库中,所谓事务是指作为单个逻辑工作单元执行的一系列操作. 事务的操作: 先定义开始一个事务,然后对数据作修改操作, 这时如果提交(COMMIT),这些修改就永久地保存下来 如果回退(ROLLBA ...
- MySql事务的隔离级别及作用
逻辑工作单元遵循一系列(ACID)规则则称为事务. 原子性:保证事务是一系列的运作,如果中间过程有一个不成功则全部回滚,全部成功则成功.保证了事务的原则性. 一致性:一致性指的是比如A向B转100块钱 ...
- [转]MySQL事务学习-->隔离级别
From : http://blog.csdn.net/mchdba/article/details/12837427 6 事务的隔离级别 设置的目的 在数据库操作中,为了有效保证并发读取数据的正确性 ...
- MySQL事务的隔离级别
为什么需要隔离 当多个线程都开启事务操作数据库中的数据时,数据库系统要能进行隔离操作,以保证各个线程获取数据的准确性,在介绍数据库提供的各种隔离级别之前,我们先看看如果不考虑事务的隔离性,会发生的几种 ...
- mysql 事务、隔离级别
一.事务的四大特性(ACID) 1.原子性(Atomicity):事务开始后所有操作,要么全部做完,要么全部不做,不可能停滞在中间环节.事务执行过程中出错,会回滚到事务开始前的状态,所有的操作就像没有 ...
- MySQL——事务ACID&隔离级别
数据库事务ACID&隔离级别 什么是事务 事务是用户定义的一个数据库操作序列.这些操作要么全执行,要么全不执行,是一个不可分割的工作单元.在关系型数据库中,事务可以是一条SQL语句,也可以是一 ...
- MySQL 事务的隔离级别
转载:https://developer.aliyun.com/article/743691?accounttraceid=80d4fddb3dc64b97a71118659e106221tozz 简 ...
随机推荐
- socket 编程 : shutdown vs close
TCP/IP 四次挥手 首先作者先描述一下TCP/IP 协议中四次挥手的过程,如果对此已经熟悉的读者可以跳过本节. 四次挥手 这是一个很经典的示例图,众所周知tcp socket 在一个生命周期中有很 ...
- 【RL系列】MDP与DP问题
推荐阅读顺序: Reinforcement Learning: An Introduction (Drfit) 有限马尔可夫决策过程 动态编程笔记 Dynamic programming in Py ...
- Mac下基于testrpc和truffle的以太坊智能合约开发环境搭建
原文地址:石匠的blog truffle是一个基于Javascript开发的一套智能合约开发框架,使用Solidity语言编写合约.truffle有一套自动的项目构建机制,集成了开发,测试和部署的各个 ...
- VMware启动Centos时出现错误Cannot open the disk 'xxxxxxx.vmdk' or one of the snapshot disks it depends on. .
今天拔装虚拟机的硬盘的时候,没有关掉虚拟机,导致虚拟打开的时候出现:Cannot open the disk 'xxxxxxx.vmdk' or one of the snapshot disks i ...
- js 的filter()方法
filter()方法使用指定的函数测试所有元素,并创建一个包含所有通过测试的元素的新数组. filter()基本语法: arr.filter(callback[, thisArg]) filter() ...
- Flexbox + js实现滑动拼图游戏
滑动拼图就是把一张图片分成几等份,打乱顺序(下图),然后通过滑动拼凑成一张完整的图片. 要实现一个拼图游戏,需要考虑怎样随机的打乱顺序,怎样交换两张图片的位置,等等.但是,使用了Flexbox布局以后 ...
- 软件团队项目第一次Sprint评价(评价人:张家军)
组号 组名 缺点及建议 1 理财猫 (1)没有附带的计算器 (2)支入支出没有详细菜单说明 (3)界面背景单调 ...
- Leetcode题库——34.在排序数组中国查找元素的第一个和最后一个位置
@author: ZZQ @software: PyCharm @file: searchRange.py @time: 2018/11/12 19:19 要求:给定一个按照升序排列的整数数组 num ...
- 第三次作业---excel导入数据库及显示(2)
发现第一次做的功能有点复杂,不能理解.而且第一次的想法是在页面上上传文件,连接并导入到数据库,并在页面上显示.后来才看到要求是直接在本地将数据导入数据库就行了,然后显示.所以才出现了一堆看不懂也解决不 ...
- Unity3D游戏开发——编程实现游戏管理器
本篇简介 本篇介绍了如何将上一篇的设计模式思想运用到实际的开发过程中. 脚本文件 (1)IGameManager:这个接口存在声明了一个属性(一个拥有getter函数的变量,属性的类型是Manager ...