我的编程空间,编程开发者的网络收藏夹
学习永远不晚

一文搞懂MySQL事务特性

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

一文搞懂MySQL事务特性

本文主要给大家简单讲讲MySQL事务特性,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望MySQL事务特性这篇文章可以给大家带来一些实际帮助。

事务特性ACID
1. Atomicity(原子性)
2. Consistency(一致性)
3. Isolation(隔离性)
4. Durability(持久性)
  • 查看事务隔离级别  
    select @@tx_isolation;
  • 开始关闭事务
//开始事务
start transaction/begin;

//提交或回滚
commit/rollback
  • 设置事务自动提交开关
    SET autocommit = {0 | 1}
  • 设置事务隔离级别
SET [GLOBAL | SESSION] TRANSACTION ISOLATION LEVEL READ COMMITTED

可选的事务隔离级别有:
REPEATABLE READ
READ COMMITTED
READ UNCOMMITTED
SERIALIZABLE
数据库并发问题
  • 读脏
    事务T1读取了事务T2未提交的更新后的数据。
  • 不可重复读
    事务T1执行过程中,事务T2提交了新数据,事务T1在事务T2提交前后读到的数据不一致。
  • 幻读
    事务T1的插入或删除(事务已提交)导致事务T2在行数上不一致的情况。
    MySQL各事务隔离级别对并发问题的解决
事务隔离级别读脏不可重复读幻读
读未提交(Read-Uncommitted)可能可能可能
读提交(Read-Committed)不可能可能可能
可重复读(Repeatable-Read)不可能不可能可能
串行化(Serializable)不可能不可能不可能
下面两个例子说明RR下是有幻读现象的
create table goods(
id int primary key,
name varchar(100),
amount int not null
);
  1. 插入幻读
事务1事务2
begin;begin;
select * from goods;
Empty set (0.00 sec)
insert into goods(id, name, amount) values(1, '苹果', 100);
commit;
insert into goods(id, name, amount) values(1, '苹果', 100);
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

对于事务1,开始表为空的,后来插入是重复的key,幻觉出现。

  1. 更新幻读
事务1事务2
begin;begin;
select * from goods;
1 row in set (0.00 sec)
insert into goods(id, name, amount) values(2, '香蕉', 100);
commit;
update goods set amount=1;
Rows matched: 2  Changed: 2  Warnings: 0

对于事务1,开始查询表有一条记录,后来更新却发现有两条数据被更新了,幻觉出现。

共享锁与排他锁
共享锁(shared (S) lock)
A kind of lock that allows other transactions to read the locked object, and to also acquire other shared locks on
it, but not to write to it.  
共享锁又叫S锁,一个事务对资源加共享锁,那么其他事务还可以对此资源加共享锁,但是不能加排他锁。也即是说对资源加共享锁意味着资源可以被读但是不能对其进行删除和修改。如果事务T1对某一资源加共享锁,在没有其他事务对此资源加共享锁的情况下那么T1还可以对此资源加排它锁。  

使用语法:
begin;
select * from tableName where id=2 lock in share mode;
commit;
排他锁(exclusive (X) lock )
A kind of lock that prevents any other transaction from locking the same row. Depending on the transaction
isolation level, this kind of lock might block other transactions from writing to the same row, or might also block
other transactions from reading the same row. The default InnoDB isolation level, REPEATABLE READ, enables
higher concurrency by allowing transactions to read rows that have exclusive locks, a technique known as
consistent read.  
排他锁又叫X锁,在事务中删除、更新以及插入都会对资源加排它锁,对资源加排它锁后就不能对其加共享锁和排它锁了。如果再加则会引起阻塞直到上一个锁释放。

使用语法:
begin;
select * from tableName where id=2 for update;

commit;

MySQL事务特性就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

一文搞懂MySQL事务特性

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

一文搞懂MySQL索引特性(清晰明了)

目录为什么要有索引?认识磁盘磁盘的结构磁盘的盘片结构定位扇区mysql与磁盘交互索引的理解测试主键索引索引的原理索引结构是否可以使用其他数据结构聚簇索引 vs 非聚簇索引总结为什么要有索引?MySQL索引的建立对于MySQL的高效运行是很
2023-04-10

一文带你搞懂JavaScript中数组的特性

数组是几乎所有编程语言的基础语法,JavaScript因为语法特性,我们更需要理解数组知识。本文从JavaScript中数组的一些特殊之处入手,通过这些少有特性的详细介绍,加深我们对数组的理解
2023-05-17

一文搞懂MySQL预编译

1、预编译的好处大家平时都使用过JDBC中的PreparedStatement接口,它有预编译功能。什么是预编译功能呢?它有什么好处呢?当客户发送一条SQL语句给服务器后,服务器总是需要校验SQL语句的语法格式是否正确,然后把SQL语句编译
2022-05-23

一文搞懂 MyBatis的事务管理机制

MyBatis是一款优秀的持久层框架,相信很多Java后端开发人员对它都不会陌生。本文将从事务概述、MyBatis实现事务的方式、事务实现源码分析方面详细解析MyBatis的事务管理机制,需要的朋友可以参考下
2023-05-20

一篇文章带你彻底搞懂Redis 事务

这篇文章主要介绍了一篇文章带你彻底搞懂Redis 事务的相关资料,需要的朋友可以参考下
2022-11-13

一文搞懂Node的的事件循环

本篇文章聊聊Nodejs中的事件循环,希望带大家搞懂Nodejs中的事件循环,从此再也不怕面试官的灵魂发问:谈一下Nodejs的事件循环!
2023-05-14

【MySQL】搞懂ACID原则和事务隔离级别

宜未雨而绸缪,毋临渴而掘井说说MySQL的事务数据库事务(Database Transaction) ,是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。一个数据库事务通常包含对数据库进行读或写的一个操作序列。它的存在包含有以下两个目
【MySQL】搞懂ACID原则和事务隔离级别
2015-04-28

编程热搜

目录