加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MYSQL数据库MySQL事务一些总结

发布时间:2020-12-12 00:59:05 所属栏目:MySql教程 来源:网络整理
导读:《MYSQL数据库MySQL事务一些总结》要点: 本文介绍了MYSQL数据库MySQL事务一些总结,希望对您有用。如果有疑问,可以联系我们。 导读:MySQL事务:1.MySQL事务控制语句(1).开启事务begin;(2).提交事务commit;(3).回滚事务rollback;(4).设置事务是否自动提交se

《MYSQL数据库MySQL事务一些总结》要点:
本文介绍了MYSQL数据库MySQL事务一些总结,希望对您有用。如果有疑问,可以联系我们。

导读:MySQL事务:1.MySQL事务控制语句(1).开启事务begin;(2).提交事务commit;(3).回滚事务rollback;(4).设置事务是否自动提交set autocommit =... MySQL事务: 1.MySQL事务控制语句 (1).开启事务 begin; (2).提交事务 commit; (3).回滚事务 rollback; (4).设置事务是否自动提交 set autocommit = {0 | 1}; // 0不自动提交,1自动提交 例如: begin;// 开启事务 insert into table_name values(内容); commit;// 提交事务 这个就是一个简单的插入数据的事务 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的数据也会被锁住,这是需要注意的.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读