mysql 开发基础系列21 事务控制和锁定语句(下)
1. 隐含的执行unlock tables
如果在锁表期间,用start transaction命令来开始一个新事务,会造成一个隐含的unlock tables 被执行,如下所示:
|
会话1 |
会话2 |
|
SELECT * FROM country WHERE country='德国'; 记录为空 |
SELECT * FROM country WHERE country='德国'; 记录为空 |
|
-- 对country表进行加 写锁 LOCK TABLE country WRITE; |
|
|
-- 查询 整个表读取被阻塞 SELECT * FROM country WHERE country='德国'; |
|
|
-- 插入一条记录 INSERT INTO country(country, last_update) VALUES('德国',NOW()); 共 1 行受到影响 country_id country last_update 2 中国 2018-07-03 18:06:45 7 德国 2018-07-12 17:22:08 |
查询等待 |
|
-- 开始一个新事务 START TRANSACTION; |
|
|
会话1开始一个新事务时,表锁被释放,可以查询: SELECT * FROM country; country_id country last_update 2 中国 2018-07-03 18:06:45 7 德国 2018-07-12 17:22:08 |
在同一个事务中,最好不要操作不同存储引擎的表, 因为只有commit 和rollback 只能对事务类型的表进行提交和回滚。通常 提交的事务记录会到二进制的日志中, 但如果一个事务中包含非事务类型的表,那么回滚操作也会被记录到二进制日志中,以确保非事务类型表的更新可以被复制到从slave数据库中。
2. savepoint
在事务中可以通过定义 savepoint,指定回滚事务的一个部分,但是不能提交提交事务的一个部分, 对于复杂的应用,可以定义多个不同的savepoint 来适应不同的条件,回滚不同的savepoint。如果定义了相同名字的savepoint,则后面定义的savepoint会覆盖之前的定义。对于不再需要使用的savepoint,可以通过release savepoint 来删除savepoint。
下面举例回滚事务的一个部分,通过定义savepoint来指定需要回滚的事务的位置。
|
会话1 |
会话2 |
|
SELECT * FROM country WHERE country='德国'; 结果为空 |
SELECT * FROM country WHERE country='德国'; 结果为空 |
|
-- 启动一个事务 插入一条记录 START TRANSACTION ; INSERT INTO country(country, last_update) VALUES('德国',NOW()); |
|
|
-- 可以查询到刚插入的记录 SELECT * FROM country WHERE country='德国'; country_id country last_update 12 德国 2018-07-12 18:17:12 |
SELECT * FROM country WHERE country='德国'; 结果为空 |
|
-- 定义savepoint 名为testsavepoint SAVEPOINT savepoint_test; -- 继续插入一条记录, 此时事务还会提交 INSERT INTO country(country, last_update) VALUES('日本',NOW()); |
|
|
SELECT * FROM country WHERE country='德国' or country='日本' 结果为空 |
|
|
SELECT * FROM country WHERE country='德国' or country='日本' country_id country last_update 12 德国 2018-07-12 18:17:12 13 日本 2018-07-12 18:20:33 |
|
|
-- 回滚刚才的定义 ROLLBACK TO SAVEPOINT savepoint_test; |
|
|
SELECT * FROM country WHERE country='德国' OR country='日本' country_id country last_update 12 德国 2018-07-12 18:17:12 |
SELECT * FROM country WHERE country='德国' or country='日本' 结果为空 |
|
-- 提交事务 COMMIT; |
|
|
SELECT * FROM country WHERE country='德国' OR country='日本' country_id country last_update 12 德国 2018-07-12 18:17:12 |
SELECT * FROM country country_id country last_update 2 中国 2018-07-03 18:06:45 12 德国 2018-07-12 18:17:12 |
mysql 开发基础系列21 事务控制和锁定语句(下)的更多相关文章
- mysql 开发基础系列20 事务控制和锁定语句(上)
一.概述 在mysql 里不同存储引擎有不同的锁,默认情况下,表锁和行锁都是自动获得的,不需要额外的命令, 有的情况下,用户需要明确地进行锁表或者进行事务的控制,以便确保整个事务的完整性.这样就需要使 ...
- (1.3)mysql 事务控制和锁定语句
(1.3)mysql 事务控制和锁定语句 lock table 参考转载自:https://www.cnblogs.com/kerrycode/p/6991502.html 关键词:mysql loc ...
- mysql 开发基础系列12 选择合适的数据类型(上)
一. char 与varchar比较 在上图的最后一行的值只适用在"非严格模式",关于严格模式后面讲到.在“开发基础系列4“ 中讲到CHAR 列删除了尾部的空格.由于char是固定 ...
- mysql事务控制和锁定语句
MySQL 支持对 MyISAM 和 MEMORY 存储引擎的表进行表级锁定,对 BDB 存储引擎的表进行页级锁定,对 InnoDB 存储引擎的表进行行级锁定.默认情况下,表锁和行锁都是自动获得的,不 ...
- mysql 开发基础系列22 SQL Model
一.概述 与其它数据库不同,mysql 可以运行不同的sql model 下, sql model 定义了mysql应用支持的sql语法,数据校验等,这样更容易在不同的环境中使用mysql. sql ...
- mysql 开发基础系列18 存储过程和函数(下)
1. 光标的使用(游标) 在存储过程和函数中可以使用光标对结果集进行循环的处理,光标使用包括光标的声明,open ,fetch,close. 下面在存储过程中使用一个光标, 这个举例中光标里的逻辑不重 ...
- mysql 开发基础系列17 存储过程和函数(上)
一. 概述 存储过程和函数是事先经过编译并存储在数据库中的一段sql语句集合,可以简化应用开发人员的很多工作,减少数据在数据库与应用服务器之间的传输,提高数据处理效率是有好处的.存储过程和函数的区别在 ...
- mysql 开发基础系列14 字符集
字符集是一套文字符号及其编码,比较规则的集合.第一个字符集是ascll(american standard code for information interchange). 1. 选择合适的字 ...
- mysql 开发基础系列10 存储引擎 InnoDB 介绍
一. 概述: InnoDB存储引擎提供了具有提交,回滚,和崩溃恢复能力的事务安全,对比MYISAM 的存储引擎,InnoDB写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引.它的特点有如下: ...
随机推荐
- Tomcat 500error: Could not initialize class
Web 项目报错Could not initialize class ,出现500,说明服务器是起来了,可能是这个类的驱动有问题,缺少初始化需要的文件 查到有相关情况: 考虑是jar 包的问题,检查了 ...
- java -version显示版本和JAvA_HOME配置不一样
当你需要安装多个版本的jdk时,可能会遇到更改了JAVA_HOME后java -version不变的情况. 一般情况下,将你的JAVA_HOME改为你要用的jdk的安装路径,然后你使用的就是这个版本的 ...
- mycat跟踪分析
mycat版本1.6 192.168.5.66 从 192.168.5.67主 一个user表 验证主从 log4j2修改日志level为debug schema.xml配置 启动服务,打开日志tai ...
- 如何往有自增标识字段的表插入数据时,同时给自增标识字段插入值呢,在Inset Into语句前后加上SQL语句:SET IDENTITY_INSERT TableName ON和SET IDENTITY_INSERT TableName OFF
当要往有设置自增标识字段的表插入数据,并希望同时设置好自增字段的值时,可以在insert into 的SQL语句前后分别加上一句sql语句,SET IDENTITY_INSERT TableName ...
- 使用@Autowird注入报空指针异常
new的对象不能调用此对象里面注入的其他类,如果想要调用注入的其他类,则此new的对象要使用@componet将此类注入. 原因:
- 《你不知道的JavaScript》三卷读后感
本系列的作者是Kyle Simpson,上卷译者赵望野.梁杰,中卷译者单业,下卷译者单业.姜南. 我个人觉得第一卷是本系列最好的(必读),而第二卷虽然也讲解了很多知识点,但是对于异步和性能的那部分提及 ...
- spring整合mybatis框架
1.导入jar包 2.配置文件 a. applicationContext.xml文件 <beans xmlns="http://www.springframework.org/ ...
- [XAF] Llamachant Framework Modules
Llamachant Framework Modules 最近更新 2018-08-22 *变更:我们从所需的模块列表中删除了审计跟踪模块.如果要在应用程序中使用Audit Trail功能,请将Aud ...
- Exp4 恶意代码分析 ——20164325王晓蕊
1.实践目标 监控你自己系统的运行状态,看有没有可疑的程序在运行. 分析一个恶意软件,就分析Exp2或Exp3中生成后门软件:分析工具尽量使用原生指令或sysinternals,systracer套件 ...
- 人工智能之一般合一算法Java实现之
import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.Scanner ...