一文搞懂MySQL事务特性
admin
2023-04-23 16:04:15
0

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

相关内容

热门资讯

“台独”顽固分子沈伯洋参选台北... 【环球时报特约记者 陈立非】台湾今年年底举行“九合一”选举,国民党很早就确定由现任台北市市长蒋万安争...
伊拉克和巴基斯坦据称已分别同伊... 总台记者当地时间5月12日获悉,伊拉克和巴基斯坦已分别同伊朗签订协议,以从海湾地区运输石油和液化天然...
京沪高铁“涨价”,调价背后有何... 昨天(11日),京沪高铁发布公告称,决定对京沪高速线、合蚌高速线动车组列车公布票价进行优化调整,时速...
第三方样品A厂家生产支架样品测... 第三方样品A厂家生产支架样品测试实验报告 一、检测范围 本次检测对象为A厂家生产的XX型医用金属...
伊朗德黑兰地区发生4.6级地震 总台记者获悉,当地时间5月12日23时47分左右,伊朗德黑兰地区发生4.6级地震。震中位于德黑兰省和...
被科威特指控“武装渗透”布比延... 新华社科威特城/德黑兰5月12日电(记者尹炣 陈霄)科威特政府12日指认,伊朗伊斯兰革命卫队多名武装...
酒吧办护士制服派对被指低俗,当... 据媒体报道,5月12日国际护士节,浙江衢州有网友发帖称,当地APK·ELITE CLUB酒吧举办所谓...
珠海冠宇获得发明专利授权:“一... 证券之星消息,根据天眼查APP数据显示珠海冠宇(688772)新获得一项发明专利授权,专利名为“一种...
大华申请数据写入方法专利,提高... 国家知识产权局信息显示,浙江大华技术股份有限公司申请一项名为“数据写入方法、电子设备及计算机可读存储...
现在,赖清德更焦虑了 执笔/月半刀&宝刀刀&胡一刀5月13日,美国总统特朗普将开启访华行程。外界高度关注此次会晤中双方将如...