登录  /  注册

MySQL中关于事务的具体详解

黄舟
发布: 2017-09-11 11:39:06
原创
1034人浏览过

MySQL事务:

1.MySQL事务控制语句

(1).开启事务

begin;
登录后复制

(2).提交事务

commit;
登录后复制

(3).回滚事务

rollback;
登录后复制

(4).设置事务是否自动提交

set autocommit = {0 | 1}; // 0不自动提交,1自动提交
登录后复制

例如:

begin;// 开启事务
insert into table_name values(内容);
commit;// 提交事务
登录后复制

这个就是一个简单的插入数据的事务

begin;// 开启事务
insert into table_name values(内容);// 后悔了,不想插入数据了
rollback;// 回滚,取消这次的事务操作
登录后复制

这个就是一个简单的插入数据的回滚事务

2.MySQL事务隔离语句

查看MySQL的隔离级别

show variables like 'tx_isolation';
登录后复制

(1).read-uncommitted(读取未提交内容)

脏读(带来的问题);

一个用户在两次查询结果中的内容不相同.

设置默认隔离级别(设置完成后需要重新登录):

set global transaction isolation level read uncommitted;
登录后复制

两个用户同时登录数据库,分别开启事务,一个用户的事务执行增删改操作,另一个用户的事务只进行查询操作,前者执行完操作,不进行提交,后者就可以看到操作结果,但如果这时候前者进行了事务的回滚,后者这时候查询就会看到不一样与上次不一样的结果(也就是没有进行操作的结果),这就是脏读问题.

(2).read committed(读取提交内容)

事务只能看见已经提交事务所做的改变,同一查询可能返回不同的结果,此级别导致的不可重复读问题.

设置默认隔离级别(设置完成后需要重新登录):

set global transaction isolation level read committed;
登录后复制

在一次事务中,看到了两次不一样的查询结果(与脏读类似).

(3).repeatable read(可重复读)

能确保同一事务的多个实例在并发读取数据时,会看到同样的数据行(数据库的莫尔纳隔离级别).

设置默认隔离级别(设置完成后需要重新登录):

set global transaction isolation level repeatable read;
登录后复制

也就在在一次事务中,无论另一个用户如何修改数据,在这次事务中查询到的结果总是相同.

***隐式事务提交***:

alter table users engine = innodb;// 会造成事务的隐式提交
登录后复制

3.InnoDB锁机制

(1).一个表中没有任何的主键和索引,一个事务会锁住这个表的所有记录,其他的事务无法进行操作这个表.

(2).一个表中存在主键或者索引,一个事务会锁住表的他操作的某行数据,不回锁住整个表,如果其他的事务操作这个表的其他数据,这个时候是不受影响的.需要注意的是这的行级锁是间隙锁,也就是说如果你修改的某几行数据,比如过修改id<10的n行数据.=,这时,id = 11的数据也会被锁住,这是需要注意的.

以上就是MySQL中关于事务的具体详解的详细内容,更多请关注php中文网其它相关文章!

相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 技术文章
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2023 //m.sbmmt.com/ All Rights Reserved | 苏州跃动光标网络科技有限公司 | 苏ICP备2020058653号-1

 | 本站CDN由 数掘科技 提供

登录PHP中文网,和优秀的人一起学习!
全站2000+教程免费学