一文搞懂MySQL事务特性
发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,本文主要给大家简单讲讲MySQL事务特性,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望MySQL事务特性这篇文章可以给大家带来一些实际帮助。事务特性A
千家信息网最后更新 2025年01月22日一文搞懂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 READREAD COMMITTEDREAD UNCOMMITTEDSERIALIZABLE
数据库并发问题
- 读脏
事务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 | 事务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 | 事务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 onit, 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 transactionisolation level, this kind of lock might block other transactions from writing to the same row, or might also blockother transactions from reading the same row. The default InnoDB isolation level, REPEATABLE READ, enableshigher concurrency by allowing transactions to read rows that have exclusive locks, a technique known asconsistent read. 排他锁又叫X锁,在事务中删除、更新以及插入都会对资源加排它锁,对资源加排它锁后就不能对其加共享锁和排它锁了。如果再加则会引起阻塞直到上一个锁释放。使用语法:begin;select * from tableName where id=2 for update;
commit;
MySQL事务特性就先给大家讲到这里,对于其它相关问题大家想要了解的可以持续关注我们的行业资讯。我们的板块内容每天都会捕捉一些行业新闻及专业知识分享给大家的。
事务
资源
隔离
数据
级别
更新
特性
一致
对此
问题
专业
幻觉
情况
苹果
行业
语法
在行
一致性
专业知识
两个
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
奶块选哪个服务器最好
贵州师范大学思政课数据库
上杭县灵子软件开发工作室
新世界美西哪个服务器人多
服务器内存6t
河北系统软件开发服务费
linux软件开发工作站
软件开发合同 律师
exe快速拆分数据库
本地数据库服务器
数据库主文件名在哪里
sql空间数据库安全性
勇芳软件开发
可以驻留在对方服务器系统
金山区网络技术转让
淄博直播软件开发解决方案
web下载服务器搭建
数据库pb的导入
计算机网络技术专业的发展
计算机专业网络技术专升本
河北政企软件开发
关系型数据库三范式
te数据库怎么连接器
未来科技互联网
东南大学本科网络安全
数据库java学哪个
博为峰软件开发培训怎么样
计算机网络技术专业的发展
先进网络技术
http服务器 下载