关系型数据库---MySQL---事务
1、概述
1.1 事务:在对业务相关的一系列数据进行操作时,需要保证数据操作的完整性(要么全部成功、要么全部失败);
1.2 MySQL中支持事务的存储引擎是:Innodb;
1.3 事务用来管理insert、update、delete语句;
1.4 事务必须满足的4个条件(ACID):
1.1.1 Atomicity(原子性)
一个事务的所有操作,要么全部成功、要么全部失败
1.1.2 Consistency(一致性)
在事务开始之前、事务结束之后,数据库的完整性没有遭到破坏
1.1.3 Isolation(隔离性)
数据库允许多个并发事务同时对数据进行读写和修改,隔离性可以防止多个事务执行时由于交叉执行而产生数据的不一致;
事务的隔离级别:读未提交read uncommitted、读提交read committed、可重复读repeatable read、串行化Serializable;
1.1.4 Durability(持久性)
事务处理完成后,对数据的修改是永久性的;
2、事务控制语句
begin(start transaction): 显示开启事务
commit(commit work): 事务提交(事务提交后对数据进行的修改称为永久性)
rollback(rollback work): 事务回滚(撤销之前对数据库的所有操作)
savepoint 保存点名称: 在事务中创建一个保存点(一个事务中可有多个savepoint)
release savepoint 保存点名称: 删除一个事务中的保存点(如果事务中不存在保存点,会抛出异常)
rollback to 保存点名称: 把事务回滚到保存点
set transaction: 设置事务的隔离级别(Innodb存储引擎支持的隔离级别:读未提交read uncommitted、
读提交read committed、可重复读repeatable read、串行化Serializable)
set autocommit=0 禁止事务自动提交(关闭自动提交后,从下一条指令开始开启新的事务,需要使用commit或rollback结束该事务)
set autocommit=0 开启事务自动提交
3、案例
【注意】:
默认情况下,每条SQL语句都可以视为一个事务,SQL执行完成后,自动执行commit;
通过begin或者set autocommit=0来禁止事务自动提交;
//每个命令后必须加分号,不然报语法错误
BEGIN;
INSERT INTO `user`(name,age) VALUES('lili',27);
INSERT INTO `user`(name,age) VALUES('lili',28);
ROLLBACK;
BEGIN;
INSERT INTO `user`(name,age) VALUES('lili',27);
INSERT INTO `user`(name,age) VALUES('lili',28);
COMMIT;
SET autocommit=0;
INSERT INTO `user`(name,age) VALUES('lili',27);
INSERT INTO `user`(name,age) VALUES('lili',28);
COMMIT;
4、并发事务 引起的问题:
脏读:
一个事务读取到了 另一个事务修改但是未进行事务提交的数据,一旦 另一个事务进行回滚,就会造成脏读;
案例:
左侧、右侧事务隔离级别设置为'read-uncommitted';
左侧手动开启事务,对id=1的数据进行更新,但未进行事务提交;
右侧对id=1的数据查询,会读取到左侧事务未提交的数据;
造成数据的脏读;

不可重复读:
一个事务执行相同的多次查询,但每次的结果都不一样,因为另一个并发事务在查询期间对数据作了修改;
案例:
左侧、右侧事务均设置为'read-committed';
左侧对id=1的数据进行更新, 并事务提交;
同时,右侧对id=1的数据查询,发现数据已经更新;
造成数据的不可重复读;

幻读:
一个事务执行相同的多次查询,发现每次查询的数量不一致,因为在查询时另一个并发事务对数据作了新增或者删除;
5、并发事务 隔离级别:

read uncommitted:
允许读取尚未提交的数据;
会造成脏读、不可重复读、幻读;
read committed:
允许读取已提交的数据;
会造成不可重复读、幻读;
repeatable read:(MySQL默认的隔离级别)
可重复读;
案例:
左侧、右侧隔离级别设置为'repeatable-read';
左侧手动开启事务,对id=1的数据进行更新,但事务未提交;
同时,右侧手动开启事务,进行id=1的数据读取;
解决了脏读的问题;

接上述;
左侧事务提交,id=1的数据更新为666;
右侧对id=1的数据进行查询,结果仍为600;
解决了不可重复读的问题;

接上述;
左侧新增一条数据,并自动进行事务提交;
右侧进行查询,发现没有读取到新增的数据(从快照中读取的,保证可重复读);
右侧对新增的数据进行更新,发现成功;
造成幻读;

Serializable:
最高的隔离级别,可防止脏读、不可重复读、幻读的发生;
性能比较低;
关系型数据库---MySQL---事务的更多相关文章
- Hadoop生态组件Hive,Sqoop安装及Sqoop从HDFS/hive抽取数据到关系型数据库Mysql
一般Hive依赖关系型数据库Mysql,故先安装Mysql $: yum install mysql-server mysql-client [yum安装] $: /etc/init.d/mysqld ...
- 第二百八十六节,MySQL数据库-MySQL事务操作(回滚)
MySQL数据库-MySQL事务操作(回滚) 事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性. 举例:有这样一张表 从表里可以看出张 ...
- MongoDB 与传统关系型数据库mysql比较
与关系型数据库相比,MongoDB的优点: 转载自 http://blog.sina.com.cn/s/blog_966e430001019s8v.html①弱一致性(最终一致),更能保证用户的访问 ...
- 关系型数据库MySql简介
什么是关系型数据库? 数据库就是用来存储数据的仓库,是一种特殊的文件. 根据存储的数据不同,划分为关系型数据库和非关系型数据库. 关系型数据库就是指 建立在关系模型基础上的数据库,通俗来讲这种数据库就 ...
- Flink RichSourceFunction应用,读关系型数据(mysql)数据写入关系型数据库(mysql)
1. 写在前面 Flink被誉为第四代大数据计算引擎组件,即可以用作基于离线分布式计算,也可以应用于实时计算.Flink的核心是转化为流进行计算.Flink三个核心:Source,Transforma ...
- 数据库-mysql事务
MySQL 事务 MySQL 事务主要用于处理操作量大,复杂度高的数据.比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数 ...
- 关系型数据库MySQL多实例
简介 MySQL数据库是一个中小型关系型数据库管理系统,软件开发者为瑞典MySQL AB公司.在2008年1月16号被Sun公司收购后Sun公司又被oracle公司收购.目前MySQL被广泛地应用在I ...
- Python3爬虫(九) 数据存储之关系型数据库MySQL
Infi-chu: http://www.cnblogs.com/Infi-chu/ 关系型数据库关系型数据库是基于关系模型的数据库,而关系模型是通过二维表来保存的,所以关系型数据库的存储方式就是行列 ...
- sqlyog管理关系型数据库mysql数据库之sqlyog的安装管理
.关系型数据库 有库有表,有关系 非关系型数据库 存储对象.集 下面的所有演示截图都是基不超过SQLyog 11进行的. 1. 2.点击上图中的应用程序,进行安装. 安装sqlyog , 账户dd0 ...
- 数据库 Mysql事务详解
Mysql事务 mysql的事务默认是自动提交的,也就是你提交一个query,他就直接执行!我们可以通过 禁止自动提交 开启自动提交 //mysql事务 #include <stdio.h> ...
随机推荐
- MySQL数据库简介
数据库就是数据的集合. 关系数据库是一种特殊的数据库,它将数据组织成表,并表示为表之间的关系. 数据库系统往往是大型项目的核心数据内容,如银行的用户账户信息.腾讯的QQ用户账户信息.股市的各种交易信息 ...
- Axure RP7.0移动互联网产品原型设计 中文pdf扫描版
移动互联网原型设计,简单来说,就是使用建模软件制作基于手机或者平板电脑的App,HTML 5网站的高保真原型.在7.0 之前的版本中,使用Axure RP进行移动互联网的建模也是可以的.比如,对于桌面 ...
- .NET DataTable DataSet转json代码
/// <summary> /// dataTable转换成Json格式 /// </summary> /// <param name="dt"> ...
- 167. Two Sum II - Input array is sorted两数之和
1. 原始题目 给定一个已按照升序排列 的有序数组,找到两个数使得它们相加之和等于目标数. 函数应该返回这两个下标值 index1 和 index2,其中 index1 必须小于 index2. 说明 ...
- 设置label的文字,一行多种颜色
调用 [self fuwenbenLabel:contentLabel FontNumber:[UIFont systemFontOfSize:] AndRange:NSMakeRange(, ) A ...
- 4.Single Number(出现一次的数)
Level: Easy 题目描述: Given a non-empty array of integers, every element appears twice except for one. ...
- appium键盘处理
最近对appium感兴趣,就从网上找了些资料,搭建了环境,下载了appium测试代码和测试apk,这方面的东西晚上再写 appium最新版(v1.4.0.0)已经没有sendKeyEvent了,所以现 ...
- 【Cracking the Code Interview(5th edition)】一、数组与字符串(C++)
1.1 实现一个算法,确定一个字符串的所有字符是否全都不同.不允许使用额外的数据结构. 解答:这里假定字符集为ASCII码,可以与面试官沟通确认字符串使用的字符集.由于字符集是有限的,建立一个数组模拟 ...
- 【转】eclipse上的.properties文件中文编辑显示问题
首先,解决.properties文件中的中文编辑问题,我们发现,在.properties文件中输入的中文变成了这个样子: 这是eclipse的.properties文件,默认的编码方式是iso-885 ...
- java编程技巧和心得
1.在一个类中修改或调用另一个类的变量: 只需要将该变量用public static 这个修饰符修饰,再用类名直接调用即可 2.实现对只有下标不同变量的操作 解决思路:可以将这些变量放在一个数组里,在 ...