bitsCN.com

MySQL事务处理及锁定

事务处理(Transaction)是将多个更新命令作为一个整体来执行,从而保证数据整合性的机制。

存储引擎(Storage Engine)

MySQL 有一个重要特征,即:可替换存储引擎构架(Pluggable Storage Engine Architecture)

MySQL 的功能分为 2 个部分,

外层部分:负责完成与客户端的连接、对 SQL 语句进行事前检查等。

内层部分:存储引擎部分,负责接收外层的数据操作指示,完成实际的数据输入输出以及文件操作。

MySQL 提供了多种存储引擎,用户可自由选择(也可以给不同的表,选择不同的存储引擎)

用户可以任意选择存储引擎,这是 MySQL 独有的特征。

MyISAM :默认的高速引擎,不支持事务处理

InnoDB :支持行锁定,以及事务处理,比 MyISAM 的处理速度稍慢

ISAM :MyISAM 引擎的前身。MySQL 5.0 以后,不再标准安装

MERGE : 该引擎,会将多个 MyISAM 类型的表,作为一个表来处理

MEMORY, HEAP : 只在内存上保存数据

Falcon :一种新的存储引擎,支持事务处理

ARCHIVE: 将数据压缩后保存 (只能进行 INSERT / SELECT 操作)

CSV : 以CSV 形式保存数据(应用于跨平台数据交换)

my.ini 中, 设置:default-storage-engine=INNODB

才能使用 InnoDB 引擎,来支持事务处理

[sql]

SHOW CREATE TABLE customer;

SHOW CREATE TABLE customer/G

[sql]

ALTER TABLE customer ENGINE=MyISAM;

为什么需要事务处理?

例如:甲,向乙转账1 万元。

需要2个操作,甲的账户减少 1万,乙的账户增加 1万。

如果,甲账户减少 1万之后,乙账户却没有相应增加1万,则发生错误。

为避免此类情况,将2个操作作为一个事务来处理,2个操作都成功,则事务结束,进行提交(COMMIT)。

如果 其中1个操作失败,则强制返回最初的状态,即:回滚(ROLLBACK)

这样,能保证,要么2个操作都成功,要么2个操作都失败。

执行ROLLBACK 等事务操作,要确保当前的数据库引擎是支持事务操作的。如:InnoDB

[sql]

BEGIN; -- 或者 START TRANSACTION

DELETE FROM customer;

SELECT * FROM customer;

ROLLBACK;

自动提交的功能,默认是开启的。

[sql]

SELECT @@AUTOCOMMIT;

SET AUTOCOMMIT=0; --关闭自动提交功能

SELECT * FROM customer;

DELETE FROM customer;

ROLLBACK; -- 关闭自动提交,无需 BEGIN 操作,也能使用 ROLLBACK

/* 这种情况下,如果不执行 COMMIT 操作,则所有更新不会反映到数据库中 */

部分回滚

[sql]

BEGIN;

INSERT INTO customer VALUES('T0001', '王二', '1980-10-21', 1);

SAVEPOINT sp;

INSERT INTO customer VALUES('T0002', '田三', '1985-10-21', 1);

SELECT * FROM customer;

ROLLBACK TO SAVEPOINT sp;

SELECT * FROM customer;

ROLLBACK;

SELECT * FROM customer;

以下 SQL 命令,执行后会被自动提交。它们不在事务处理的控制范围之内。

[sql]

DROP DATABASE;

DROP TABLE;

DROP;

ALTER TABLE;

多用户同时读取数据库时候,为防止冲突,可使用锁定(Lock)、解锁(Unlock)

锁定分为:共享锁定(Shared Lock)、排他锁定(eXclusive Lock)

共享锁定,有时也称为,读取锁定。当用户参照数据时,将对象数据变为只读形式。

排他锁定,也称为,写入锁定 或 独占锁定。

在执行 INSERT、UPDATE、DELETE 等操作时,使用该锁定。其他进程、事务,一律不能读取、更新、写入。

锁定粒度:记录(行)、表、数据库。

锁定提升机制:当行单位粒度的锁定,大量产生时,数据库将锁定粒度自动向上提升(比如,提升成表粒度的锁定,或者数据库粒度的锁定)

分离水平:事务处理之间的影响程度(同时运行时互相影响的机制)

分离水平有 4 种:

READ UNCOMMITTED :支持, 非提交读取、不可重复读取、幻象读取

READ COMMITTED :支持,不可重复读取、幻象读取

REPEATABLE READ :支持,幻象读取

SERIALIZABLE :都不支持

非提交读取(脏读 Dirty Read):能从别的事务处理中,读取到尚未提交的更新数据,只发生在 READ UNCOMMITTED 分离水平。不推荐使用

[sql]

SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;

不可重复读取(Non-Repeatable Read):某一事务处理中,由于其他事务处理的更新操作,导致,对同一数据的多次读取,结果不同。

发生在 READ COMMITED 以下的分离水平

幻象读取(Phantom Read):某一事务处理中,对同一数据进行多次读取时,由于其他事务处理的插入、删除操作,

使得结果中,出现了第一读取时,不存在的数据,或者,第一次读取时,存在的数据消失了,的现象。

死锁(Dead Lock)两个不同的事务处理,在相互等待对方释放锁定,永远也不可能解除锁定的一种状态。

事务处理的机制,简单的说,就是,留下更新日志。

与事务处理相关的日志,分为2个类型:UNDO 日志、 REDO 日志

UNDO 日志,又称:回滚段(Rollback Segment)

REDO 日志,又称:事务处理日志、或 日志。

bitsCN.com

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

TAG标签:存储

mysql 事务中锁处理_MySQL事务处理及锁定_MySQL相关推荐

  1. Mysql 事务中Update 会锁表吗?

    Mysql 事务中Update 会锁表吗? 两种情况: 1.带索引 2.不带索引 前提介绍: 方式:采用命令行的方式来模拟 1.mysq由于默认是开启自动提交事务,所以首先得查看自己当前的数据库是否开 ...

  2. 超详细图解!【MySQL进阶篇】MySQL事务和锁

    ACID 特性 在关系型数据库管理系统中,一个逻辑工作单元要成为事务,必须满足这 4 个特性,即所谓的 ACID: 原子性(Atomicity).一致性(Consistency).隔离性(Isolat ...

  3. 使我郁郁寡欢的 MySQL 事务和锁

    1 事务的ACID 特性 事务是一组 SQL 语句,它们是一个执行单位.InnoDB 里面每个事务有一个唯一的事务 ID,叫作 transaction id.它是在事务开始的时候向 InnoDB 的事 ...

  4. 五、Mysql事务以及锁原理

    五.Mysql事务以及锁原理 事务(ACID) 场景:小明向小强转账10元 原子性(Atomicity) 转账操作是一个不可分割的操作,要么转失败,要么转成功,不能存在中间的状态,也就是转了一半的这种 ...

  5. 盘一盘MySQL事务和锁

    MySQL事务与锁 事务 事务的概念 事务Transaction,是指作为一个Session执行的一系列SQL语句的操作,要么完全的执行,要么完全的都不执行. 事务最经典也经常被拿出来说例子就是转账了 ...

  6. mysql innodb禁用事务_MySQL InnoDB事务中锁问题(三)

    试想,事务如果都是串行的,那么就不需要锁了,但是性能肯定没法接受.加锁只是为了提高事务并行度,并且解决并发事务执行过程中引起的脏写.脏读.不可重复读.幻读这些问题的一种解决方案(MVCC算是一种解决脏 ...

  7. mysql如何实现读提交锁_MySQL学习笔记(二)—MySQL事务及锁详解

    一.事务 数组库的一组操作,要么全部成功,要么全部失败 举例:银行转账 A账户向B账户转100 A账户余额扣去100 B账户余额增加100 上述两个操作要么全部成功,要么全部失败,部分成功或失败,数据 ...

  8. 面试中的老大难-mysql事务和锁,一次性讲清楚!

    转自:https://juejin.cn/post/6855129007336521741 众所周知,事务和锁是mysql中非常重要功能,同时也是面试的重点和难点.本文会详细介绍事务和锁的相关概念及其 ...

  9. mysql事务与锁_mysql之事务和锁

    并发控制: MVCC 多版本并发控制. 用户在操作时操作的是带有时间点的快照.而不是表本身.最后将快照进行合并. 锁: 读锁:共享锁.读取操作不会对用户之间产生影响. 写锁:独占锁.一个用户写入时,其 ...

最新文章

  1. java如何追加写入txt文件
  2. SQLServer中的数据类型
  3. layui --- [结构优化]参数优化
  4. Linux shell 脚本实例
  5. python自制语音识别_今天的语音识别,我们就用Python来做,从基础的知识到实践的运用...
  6. Ax 2012批量部署报表
  7. 信号与线性系统分析(第四版,吴大正主编)——信号与系统
  8. C语言钩子函数获取键盘事件,(C#)透过键盘钩子获取ScanCode/VkCode
  9. 前端实战项目:vue+elementUI管理平台
  10. adb 黑域app_黑域app怎么用?新版黑域app使用图文教程
  11. pytorch读取tif文件方法
  12. 网元的概念 --- 分布式1
  13. win7系统如何映射服务器,win7系统如何映射网络驱动器 win7系统映射网络驱动器方法...
  14. 图计算发展简史(1)
  15. 《自控力》-- 精华摘抄
  16. 两个和尚的故事【摘】
  17. 51单片机与蜂鸣器实现摩斯密码转换。
  18. 在线记录源码调试之@Qualifier源码分析
  19. 第九章 我国农村个体工商业
  20. 车载通信协议-列车实时数据协议(TRDP)

热门文章

  1. MySQL可以生成E-R图嘛_使用Navicat for mysql生成E-R图,添加外键约束
  2. hbase sqoop 实验_Hive/hbase/sqoop的基本使用教程~
  3. python 类函数 实例函数_python_30期【实例函数 类里面的函数】
  4. mysql-fron快速写sql语句,SQL优化系列:如何书写高质量SQL语句(一)
  5. python内置对象是什么_Python的内置对象类型——元组、文件,python
  6. eclipse java import_java – Eclipse:将源代码的import文件夹导入...
  7. 元宵节正月十五主题海报还没设计好,PSD分层模板来喽!
  8. 梦幻飞屋创意房产海报,温馨画面,梦中的家园
  9. 实用UI素材|UI中的按钮设计
  10. linux下的汇编,linux下的汇编分析