MySQL中事物的详解

1. 事物的定义及特性

事务是一组操作数据库的SQL语句组成的工作单元,该工作单元中所有操作要么同时成功,要么同时失败。事物有如下四个特性,ACID简称“酸性”。

1)原子性:工作单元中所有的操作要么都成功,要么都不成功,不会出现部分成功的情况。

2)一致性:工作完成其结果应与预期一致,比如由A账户向B账户转账的事物,若该事物执行成功则必须保证A账户转出多少钱,B账户相应转入多少钱;若该事物失败,则此次转账即失败。事物的其它三个性质都是为了保证该一致性的。

3)隔离性:隔离性还可以称为并发控制、可串行化、锁等。事物中所操作的数据要隔离起来,以防止其他用户访问这些数据而带来的不一致情况。

4)持久性:事务一旦提交,其所做的修改就会永久保存到数据库中,即使数据库发生故障也不应该对其有任何影响。

事务的持久性不能做到100%的持久,只能从事务本身的角度来保证永久性,而一些外部原因导致数据库发生故障,如硬盘损坏,那么所有提交的数据可能都会丢失。

2. MySQL中开启事务的方法

2.1.方法一

用BEGIN或START TRANSACTION来开启一个事物,COMMIT或ROLLBACK来结束该事物。

-- 保存点 savepoint  
begin  declare is_error int default false;#是否出错的标志  declare continue handler for sqlexception  set is_error=true;#声明异常处理程序,如果sql异常,则把标志为设置为true  start TRANSACTION;#开启事务,则会同时失败,同时成功  savepoint s1;#创建保存点  insert into employee(id,name,salary) values(146,'cq',9000);  savepoint s2;  insert into employee(id,name,salary) values(101,'cq',9000);  insert into employee(id,name,salary) values(102,'cq',9000);  if is_error THEN  rollback to savepoint s1;-- 还原到s1  insert into employee(id,name,salary) values(151,'cq',9000);  insert into employee(id,name,salary) values(152,'cq',9000);  commit;  end if;  
end;  
View Code

2.2.方法二

关闭自动提交,设置SET AUTOCOMMIT = 0,该语句后的所有操作都将变成事物操作,而且关闭自动提交的情况下,每个事物结束其后续操作都将开启新的事物。

set autocommit=0;#关闭自动提交  
#因为关闭了自动提交事务,则添加数据不会保存到数据库中  
insert into employee(id,name,salary) values(143,'cq',9000);  
commit;#手动提交所有未执行的数据 
#由于是关闭自动提交的方式开启的事务,所以每个事物结束其后的操作自动开启新的事物
insert into employee(id,name,salary) values(258,'wd',8000); #该操作属于新启的事物

3. 事物的隐式提交

由于事物不能被嵌套,所以当新事物开启时其前的旧事物会被隐式提交。如下情况会导致事物被隐式提交:

1)新事物的开启会导致旧事物的隐式提交

START TRANSACTION;
INSERT INTO `dm_性别`(性别名称) VALUES('不限');#该操作会被隐式提交
START TRANSACTION;
INSERT INTO `dm_性别`(性别名称) VALUES('男女');
ROLLBACK;

2)InnoDB中所有的DDL或DCL操作都会开启一个新的事物,所以DDL或DCL语句会导致旧事物的隐式提交

SET AUTOCOMMIT = 0;#利用法二关闭自动提交来开启事务 
BEGIN;  
INSERT INTO t1 VALUES (1); 
#该DDL语句会导致其前面的插入操作隐式提交 ,并开启一单一的事物
CREATE TABLE t2 (pk int primary key);
INSERT INTO t2 VALUES (2); #自动开启新的事物 
ROLLBACK; #插入表t1的数据已提交,仅能回滚插入表t2的操作

3)过程的执行区结束End之前会有一次隐式提交

BEGIN
START TRANSACTION;
INSERT INTO `dm_性别`(性别名称) VALUES('不限');
INSERT INTO `dm_性别`(性别名称) VALUES('男女');
END #在此之前会导致事物的隐式提交

4. 有关事物操作的注意事项

①  存储过程的执行区Begin会开启一个事物,执行区结束End会隐式提交一次

BEGIN
INSERT INTO `dm_性别`(性别名称) VALUES('不限');
INSERT INTO `dm_性别`(性别名称) VALUES('男女');
## COMMIT隐式提交该执行区域的操作
END

②  不要在事物的中途进行提交操作,一方面会破坏事物的原子性 ,另一方面该事物会到此结束

create table testproc(id int(4) primary key, name varchar(100));
#测试过程
CREATE PROCEDURE test_proc_ins(  
IN i_id INT,  
IN i_name VARCHAR(100)  
)  
BEGIN  
start transaction; #本意是将两次插入操作捆绑成一个事物  INSERT INTO testproc VALUES (i_id, i_name);  
COMMIT;#由于中途提交导致该事物提交前结束,其后的操作不再是事物操作INSERT INTO testproc VALUES (i_id, i_name); #这里故意违反主键约束 
ROLLBACK;#由于第一条插入数据的操作已提交,故这里的ROLLBACK无效
END;

③  由于DDL或DCL操作会创建新的事物,这导致其前的操作会隐式提交,从而破坏事物的原子性,所以尽量不要在过程中使用DDL或DCL语句。而且在过程中使用DDL或DCL语句的语法是比较复杂的,所以不建议在过程中使用DDL或DCL语句。

SET AUTOCOMMIT = 0;  
BEGIN;  
INSERT INTO t1 VALUES (1);  
#该DDL语句开启新事物会隐式提交其前的事物 
CREATE TABLE t2 (pk int primary key);
INSERT INTO t2 VALUES (2); ROLLBACK; SHOW TABLES

④  Start Transaction(Begin)与闭自动提交开启事务的区别:

Start Transaction只开启了一个当前事物,该事物结束其后的操作将不再是事物操作;但关闭自动提交的方式开启事务,每个事物结束其后的操作自动默认为新的事物操作。

⑤  MySQL的事务支持不是绑定在MySQL服务器本身,而是与存储引擎相关:

1.MyISAM:不支持事务,用于只读程序提高性能

2.InnoDB:支持ACID事务、行级锁、并发

3.Berkeley DB:支持事务

 

转载于:https://www.cnblogs.com/leiblog/p/9298225.html

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

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

相关文章

edittext 属性

1.去掉edittext的底线,设置,不管是edittext,还是appcompatEdittext都是这个属性 转载于:https://www.cnblogs.com/hechangshou/p/9301004.html

springboot 配置webservice接口

导入依赖的jar <!-- webservice cxf --><dependency><groupId>org.apache.cxf</groupId><artifactId>cxf-rt-frontend-jaxws</artifactId><version>3.1.6</version></dependency><dependency><groupId>org…

【Django】认证系统

目录 #. auth模块1. 认证 authenticate()2. 登陆 login(HttpRequest, user)3. 注销 logout(request)4. 认证判断 is_authenticated()5. 登陆校验 login_requierd()6. 创建普通用户 create_user()7. 创建超级用户 create_superuser()8. 密码校验 check_password(password)9. 修改…

尝试修改源码需要用到git存一下

git reflog查看本地记录 git reset --hard 02a3260 转载于:https://www.cnblogs.com/smzd/p/8492065.html

poj3713 Transferring Sylla 枚举+tarjan判割点

其实就是判断是否为三连通图 三连通图指的是去掉3个点就不连通的图&#xff0c;但是并没有直接求三连通的算法。著名的Tarjan算法可以求解连通和割点&#xff0c;再枚举删除一个点就能达到三连通的目的。 先看用例2&#xff0c;是由用例1去掉一条边而变成非三连通图的&#xff…

Linux 安装Zookeeper单机版(使用Mac远程访问)

阅读本文需要先阅读安装Zookeeper<准备> 新建目录 mkdir /usr/local/zookeeper 解压 cd zookeeper压缩包所在目录 tar -xvf zookeeper-3.4.12.tar.gz -C /usr/local/zookeeper 新建目录 mkdir /usr/local/zookeeper/zookeeper-3.4.12/data 配置文件准备 cp /usr/local/zo…

深入vue

转载于:https://www.cnblogs.com/smzd/p/8547748.html

html--form表单常用操作

form表单 用于收集用户信息&#xff0c;如&#xff1a;登录、注册等场景&#xff1b;所有要提交的数据都必须放在form标签中<form action" " method" "> action&#xff1a;提交地址、动作&#xff0c;与input标签中type标签的submit属性相关联。 &…

MySQL触发器(转载)

触发器&#xff08;trigger&#xff09;是数据库中的一个很重要的、很实用的基于事件的处理器&#xff0c;在处理一些业务需求的时候&#xff0c;使用触发器会很方便。似乎在《高性能MySQL》中&#xff0c;对触发器作了一定的描述&#xff0c;也提到使用中的一些优势和局限性&a…

神级bug解决方法

真的是神级bug,util包中的Arrays类导入不了&#xff0c;一直报错。原因&#xff1a;JDK 1.8和Myeclipse 8.5不兼容&#xff0c;导致java.util.Arrays类无法被编译。所以报错。解决方法&#xff1a;1.降低jdk版本。2.升高Myeclipse版本转载于:https://www.cnblogs.com/yanlongw/…

es6注意点

补救方法&#xff1a; 详情&#xff1a;http://es6.ruanyifeng.com/#docs/array 取出文本内容 实现深拷贝 jq实现不完全深拷贝 jQuery.extend jQuery.fn.extend function () {var options, name, src, copy, copyIsArray, clone,target arguments[0] || {},i 1,length ar…

input标签用法解读

HTML5/HTML中标签用法解读 OK&#xff01;今天博主为小伙伴们介绍的内容是HTML5/HTML中标签的用法&#xff0c;&#xff0c;&#xff0c; &#xff0c;emmm图文并茂哦&#xff01; 下面正式开始内容的介绍&#xff1a;首先&#xff0c;直观上说标签规定了用户可以在其中输入数据…

软件开发文档整理(之)一张示意图 | 清晰明了

在整个软件开发周期&#xff0c;开发文档是必不可少的资料&#xff0c;它们贯穿于整个开发周期&#xff0c;用来评估计划、规划进度、项目管理、软件测试、软件发布&#xff0c;可以说至关重要。   开发文档必须归档&#xff0c;没有归档的文档作用大打折扣&#xff0c;时效性…

《SQL Server 2008从入门到精通》--20180717

目录 1.触发器1.1.DDL触发器1.2.DML触发器1.3.创建触发器1.3.1.创建DML触发器1.3.2.创建DDL触发器1.3.3.嵌套触发器1.3.4.递归触发器1.4.管理触发器1.触发器 触发器是一种特殊的存储过程&#xff0c;与表紧密关联。 1.1.DDL触发器 当服务器或数据库中发生数据定义语言&#xff…

主成分分析原理解释(能力工场小马哥)

主成分分析&#xff08;Principal components analysis&#xff09;-最大方差解释 在这一篇之前的内容是《Factor Analysis》&#xff0c;由于非常理论&#xff0c;打算学完整个课程后再写。在写这篇之前&#xff0c;我阅读了PCA、SVD和LDA。这几个模型相近&#xff0c;却都有自…

vue全面介绍--全家桶、项目实例

简介 “简单却不失优雅&#xff0c;小巧而不乏大匠”。 2016年最火的前端框架当属Vue.js了&#xff0c;很多使用过vue的程序员这样评价它&#xff0c;“vue.js兼具angular.js和react.js的优点&#xff0c;并剔除了它们的缺点”。授予了这么高的评价的vue.js&#xff0c;也是开…

吴恩达机器学习笔记 —— 9 神经网络学习

本章讲述了神经网络的起源与神经元模型&#xff0c;并且描述了前馈型神经网络的构造。 更多内容参考 机器学习&深度学习 在传统的线性回归或者逻辑回归中&#xff0c;如果特征很多&#xff0c;想要手动组合很多有效的特征是不现实的&#xff1b;而且处理这么大的特征数据量…

vue.js开发环境搭建

环境准备 Node.js Javascript的运行时环境npm Node.js下的包管理工具webpack 前端资源模块化管理和打包工具vue-cli 脚手架构建工具cnpm npm的淘宝镜像 Vue.js安装 Node.js的安装非常容易&#xff0c;首先从官网下载你所需操作系统的版本&#xff0c;然后一直下一步就ok&…

正则基础知识

创建正则表达式 1.使用new来创建 var exp new RegExp(box , gi );g 全局匹配 i 忽略大小写 m 多行匹配2.使用字面量 var exp /box/gi; 直接用2个 / ; 在俩个斜杠后加上模式修饰符&#xff1b; 俩种创建方式比较: 1.使用字面量方式创建用的更加广泛; 2.当要匹配的内容是变量时,…

Promise实践

var doSomething function() { return new Promise((resolve, reject) > { resolve(返回值); }); };let doSomethingElse function() { return 新的值; }doSomething().then(function () { return doSomethingElse(); }).then(resp > { console.warn(resp); console.wa…