微信号:grzlwx

介绍:光荣之路官方资讯

一千行MySQL学习笔记(七)

2015-07-19 22:04 光荣之路



此笔记为作者初学MySQL时做的笔记,边学边更新,温故而知新。如果你也在学习,欢迎把你的学习笔记及新得分享给我们!735821166@qq.com


/* 事务(transaction) */ ------------

事务是指逻辑上的一组操作,组成这组操作的各个单元,要不全成功要不全失败。

- 支持连续SQL的集体成功或集体撤销。

- 事务是数据库在数据晚自习方面的一个功能。

- 需要利用 InnoDB 或 BDB 存储引擎,对自动提交的特性支持完成。

- InnoDB被称为事务安全型引擎。

-- 事务开启

START TRANSACTION; 或者 BEGIN;

开启事务后,所有被执行的SQL语句均被认作当前事务内的SQL语句。

-- 事务提交

COMMIT;

-- 事务回滚

ROLLBACK;

如果部分操作发生问题,映射到事务开启前。

-- 事务的特性

1. 原子性(Atomicity)

事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。

2. 一致性(Consistency)

事务前后数据的完整性必须保持一致。

- 事务开始和结束时,外部数据一致

- 在整个事务过程中,操作是连续的

3. 隔离性(Isolation

多个用户并发访问数据库时,一个用户的事务不能被其它用户的事物所干扰,多个并发事务之间的数据要相互隔离。

4. 持久性(Durability)

一个事务一旦被提交,它对数据库中的数据改变就是永久性的。

-- 事务的实现

1. 要求是事务支持的表类型

2. 执行一组相关的操作前开启事务

3. 整组操作完成后,都成功,则提交;如果存在失败,选择回滚,则会回到事务开始的备份点。

-- 事务的原理

利用InnoDB的自动提交(autocommit)特性完成。

普通的MySQL执行语句后,当前的数据提交操作均可被其他客户端可见。

事务是暂时关闭“自动提交”机制,需要commit提交持久化数据操作。

-- 注意

1. 数据定义语言(DDL)语句不能被回滚,比如创建或取消数据库的语句,和创建、取消或更改表或存储的子程序的语句。

2. 事务不能被嵌套

-- 保存点

SAVEPOINT 保存点名称 -- 设置一个事务保存点

ROLLBACK TO SAVEPOINT 保存点名称 -- 回滚到保存点

RELEASE SAVEPOINT 保存点名称 -- 删除保存点

-- InnoDB自动提交特性设置

SET autocommit = 0|1; 0表示关闭自动提交,1表示开启自动提交。

- 如果关闭了,那普通操作的结果对其他客户端也不可见,需要commit提交后才能持久化数据操作。

- 也可以关闭自动提交来开启事务。但与START TRANSACTION不同的是,

SET autocommit是永久改变服务器的设置,直到下次再次修改该设置。(针对当前连接)

START TRANSACTION记录开启前的状态,而一旦事务提交或回滚后就需要再次开启事务。(针对当前事务)


/* 锁表 */

表锁定只用于防止其它客户端进行不正当地读取和写入 MyISAM 支持表锁,InnoDB 支持行锁


-- 锁定

LOCK TABLES tbl_name [AS alias]

-- 解锁

UNLOCK TABLES

 
            
 
            
 
            
 
           
 
           
 
           
 
           
 
           
 
           
 
           
 
           
 
           
 
           

(你一直坚持在追这篇笔记吗?为自己呱唧呱唧,继续加油!)

(作者:Shocker 来源:http://www.cnblogs.com/shockerli/p/1000-plus-line-mysql-notes.html)

一字一句当思来之不易,感谢作者,传播测试知识、技能与正能量!

光荣之路软件测试培训

官网:http://www.gloryroad.cn/

微信公众号:gloryroadtrain

性能测试QQ群:415987441
软件测试招聘QQ群: 203715128
自动化3群QQ: 371211499


 
光荣之路 更多文章 今天晚上的 linux 公开课- Awk 编程 7月28日(今天)晚上的 linux 公开课- shell编程 8月4日(今天)晚上的 linux 公开课- shell编程 9月1日(本周一)晚8点半,光荣之路Web自动化系列基础课—javascript第二讲 推荐本好书《与机器赛跑》
猜您喜欢 Java设计模式(二) 工厂方法模式 病毒营销时代,口碑依旧打动人心 【详解】为什么选择Kubernetes作为云平台的微服务治理框架 关注技术管理的同学有福了 Google引入云函数(Cloud Functions)服务