首页 / MYSQL / MySQL中关于事务的具体详解
MySQL中关于事务的具体详解
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL中关于事务的具体详解,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2086字,纯文字阅读大概需要3分钟。
内容图文
![MySQL中关于事务的具体详解](/upload/InfoBanner/zyjiaocheng/538/0d53e90871464c5f82559a7becfcab49.jpg)
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中关于事务的具体详解的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的MySQL中关于事务的具体详解全部内容,希望文章能够帮你解决MySQL中关于事务的具体详解所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。