mysql-7事务管理
1.事务的使用场景
mysql事务主要用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人愿,你既需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务。
- 在mysql中只有使用了Innodb数据库引擎的数据库或表,才能支持事务。
- 事务处理可以用来维护数据库的完整性,保证成批的SQL语句要么全部执行,要么全部不执行。
- 事务用来管理insert update delete语句。
在mysql命令行的默认设置下,事物都是自动提交的,即执行sql语句后就会马上执行commit操作。因此要显式的开启一个事务,必须使用命令begin或start或start transaction,或者执行命令set autocommit=0,用来禁止使用当前会话的自动提交。
2. 事务控制语句:
- begin或start transaction:显式的开启一个事务
- commit:提交事务,并使已对数据库进行的所有修改成为永久性的。等价于commit work
- rollback:回滚会结束用户的事务,并撤销正在进行的所有未提交的修改,等同于rollback work
- savepoint identifier:savepoint允许在事务中创建一个保存点,一个事务中可以有多个savepoint
- release savepoint identifier:删除一个事务的保存点,当没有指定的保存点,执行该语句会抛出一个异常。
- rollback to identifier:把事务会滚到标记点
- set transaction:用来设置事务的隔离级别。InnoDB存储引擎提供事务的隔离级别有read uncommitted、read committed、repeatable read和serializable
3.事务处理主要有2种方法
3.1.begin、rollback、commit来实现
- begin:开始一个事务
- rollback:事务会滚
- commit:事务确认
3.2.直接用set来改变mysql的自动提交模式
- set autocommit=0 当前session禁用自动提交事物,自此句执行以后,每个SQL语句或者语句块所在的事务都需要显示"commit"才能提交事务。
- set autocommit=1 开启自动提交
4.事务处理中查看数据
事务处理中,需要排除session的干扰,每次执行后,通过终端在mysql下查看数据,不要在客户端查看。
docker exec -it csjmysql sh
mysql -u root -p
select * from csj_transaction_test;
5.数据确认提交因素autocommit
5.1.场景1:创建一个innodb类型的表,禁止自动提交。插入数据。
结果:数据没有提交
drop table if exists csj_transaction_test;
create table csj_transaction_test (id int(5),name varchar(20)) engine=innodb;
set autocommit=0;
insert into csj_transaction_test VALUES (1,"tom");
-- 使用终端查看
select * from csj_transaction_test;

第二步:在场景1的基础上,使用事务管理继续执行
结果:第一步的数据提交成功,第二步的数据没有提交
begin;
-- 执行begin,先对之前的操作commit,再开始下一个事务。如果没有begin,执行的操作依然不会被提交。
insert into csj_transaction_test values(2,"jerry");
-- 使用终端查看
select * from csj_transaction_test;

5.2.场景2:创建一个innodb类型的表,允许自动提交,插入数据。
结果:数据自动提交
drop table if exists csj_transaction_test;
create table csj_transaction_test (id int(5),name varchar(20)) engine=innodb;
set autocommit=1;
insert into csj_transaction_test values(2,"jerry");
-- 使用终端查看
select * from csj_transaction_test;

第二步:在场景2的基础上,执行事务管理
结果:第二部的数据没有提交
begin;
insert into csj_transaction_test values (2,"jerry");
-- 使用终端查看。
-- 如果用事务,需要commit;否则,不会执行
select * from csj_transaction_test;

5.3.场景3:创建一个普通表,禁止自动提交。插入数据
结果:数据没有提交
drop table if exists csj_transaction_test;
create table csj_transaction_test (id int(5),name varchar(20))
set autocommit=0;
insert into csj_transaction_test VALUES (1,"tom");
-- 使用终端查看
select * from csj_transaction_test;

5.4.场景4:创建一个普通表,允许自动提交。插入数据
结果:数据自动提交
drop table if exists csj_transaction_test;
create table csj_transaction_test (id int(5),name varchar(20));
set autocommit=1;
insert into csj_transaction_test values(2,"jerry");
-- 使用终端查看
select * from csj_transaction_test;

结论:
- 1.innodb只是一种数据库引擎,提供了事务的隔离级别,不会改变数据库的自动提交属性。是否提交当前和autocommit的值有关。
- 2.如果使用事务管理。begin会对先前的操作进行提交;begin之后的操作需要commit才能提交。
6.事务示例
示例1:基于3.1
drop table if exists csj_transaction_test;
create table csj_transaction_test (id int(5),name varchar(20)) engine=innodb;
begin;
insert into csj_transaction_test VALUES (1,"tom");
insert into csj_transaction_test values(2,"jerry");
commit;
-- 使用终端查看
select * from csj_transaction_test;

示例2:基于3.1
drop table if exists csj_transaction_test;
create table csj_transaction_test (id int(5),name varchar(20)) engine=innodb;
begin;
insert into csj_transaction_test VALUES (1,"tom");
insert into csj_transaction_test values(2,"jerry");
rollback;
-- 使用终端查看
select * from csj_transaction_test;

示例3:基于3.2
```#sql
drop table if exists csj_transaction_test;
create table csj_transaction_test (id int(5),name varchar(20)) engine=innodb;
set autocommit=0;
insert into csj_transaction_test VALUES (1,"tom");
insert into csj_transaction_test values(2,"jerry");
commit;
-- 使用终端查看
select * from csj_transaction_test;
```

mysql-7事务管理的更多相关文章
- mysql之事务管理
本文内容: 什么是事务管理 事务管理操作 回滚点 默认的事务管理 首发日期:2018-04-18 什么是事务管理: 可以把一系列要执行的操作称为事务,而事务管理就是管理这些操作要么完全执行,要么完全不 ...
- 实验十三 MySQL多用户事务管理
实验十三 MySQL多用户事务管理 一. 实验内容: 1. 事务机制的使用 2. 锁机制的使用 二. 实验项目:员工管理数据库 用于企业管理的员工管理数据库,数据库名为YGGL中,YGGL数据库中 ...
- Spring+Mybatis+MySql+Maven 简单的事务管理案例
利用Maven来管理项目中的JAR包,同时使用Spring在业务处理层进行事务管理.数据库使用MySq,数据处理层使用Spring和Mybatis结合. 本案例代码主要结构如图: 1.数据库脚本 -- ...
- MySQL存储过程之事务管理
原文链接:http://hideto.iteye.com/blog/195275 MySQL存储过程之事务管理 ACID:Atomic.Consistent.Isolated.Durable 存储程序 ...
- 测试MySQL事务管理
1.MySQL 版本 mysql> select version(); +------------+ | version() | +------------+ -log | +--------- ...
- MySQL事务及Spring事务管理
事务,是在数据库中用于保证数据正确性的一种机制,涉及到很多概念以及不同的情况,这里做一个总结 相关概念 事务四特性(ACID) 原子性(Atomicity,或称不可分割性):要么全部完成或者全部不完成 ...
- Mysql事务与JDBC事务管理
一.事务概述 1.什么是事务 一件事情有n个组成单元 要不这n个组成单元同时成功 要不n个单元就同时失败 就是将n个组成单元放到一个事务中 2.mysql的事务 默认的事务:一条sql语句就是一个事务 ...
- 10.mysql事务管理及python操作
在用户操作MySQL过程中,对于一般简单的业务逻辑或中小型程序而言,无需考虑应用MySQL事务.但在比较复杂的情况下,往往用户在执行某些数据操作过程中,需要通过一组SQL语句执行多项并行业务逻辑或程序 ...
- Oracle、MySQL和Sqlserver的事务管理、分页和别名的区别
1.在mysql中事务默认是自动提交的,只有设置autocommit为0的时候,才用自己commit(commit--rollback回滚) 2.但是在oracle中必须自己commit;不然就只能结 ...
- Spring基于AOP的事务管理
Spring基于AOP的事务管理 事务 事务是一系列动作,这一系列动作综合在一起组成一个完整的工作单元,如果有任何一个动作执行失败,那么事务 ...
随机推荐
- [SpringBoot] - 配置文件的多种形式及优先级
学习两个注解: @PropertySource @ImportResource ↓ @ConfigurationProperties 与 @Bean 结合为属性赋值 与 ...
- [调参]CV炼丹技巧/经验
转自:https://www.zhihu.com/question/25097993 我和@杨军类似, 也是半路出家. 现在的工作内容主要就是使用CNN做CV任务. 干调参这种活也有两年时间了. 我的 ...
- Gym - 101334C 3514 无向仙人掌
http://codeforces.com/gym/101334/attachments 题意: 判断是否是仙人掌图并且连通,如果是的话则计算出它有多少个连通子图也是仙人掌. 思路:连通子图也就是我们 ...
- [原][osgearth]osgearthElvation中的一帧
create tile key contains 获取tile上的临界值 这里先获取层数的切份(下图) 然后使用xmin,xmax,ymin,ymax获取tile的四个点 再通过geoextent获取 ...
- javascript之反柯里化(uncurrying)
在JavaScript中,当我们调用对象的某个方法时,其实不用去关心该对象原本是否被设计为拥有这个方法,这是动态类型语言的特点.可以通过反柯里化(uncurrying)函数实现,让一个对象去借用一个原 ...
- Angular i18n
Angular2中使用ngx-translate进行国际化http://blog.csdn.net/u014291497/article/details/61233033 在 Angular 项目中添 ...
- django网站
https://www.djangoproject.com/download/ 指定版本安装django命令:pip install Django==1.11.8
- bzoj2120: 数颜色 带修莫队
墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会像你发布如下指令: 1. Q L R代表询问你从第L支画笔到第R支画笔中共有几种不同颜色的画笔. 2. R P ...
- EBS 定义并发参数常用值集
1.ORG_ID 2.DATE 3.YES_NO
- LINUX中的RCU机制的分析
RCU机制是Linux2.6之后提供的一种数据一致性访问的机制,从RCU(read-copy-update)的名称上看,我们就能对他的实现机制有一个大概的了解,在修改数据的时候,首先需要读取数据,然后 ...