MYSQL数据库MySQL事务一些总结

MYSQL数据库MySQL事务一些总结,第1张

概述介绍《MYSQL数据库MySQL事务一些总结》开发教程,希望对您有用。

《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的数据也会被锁住,这是需要注意的. 总结

以上是内存溢出为你收集整理的MYSQL数据库MySQL事务一些总结全部内容,希望文章能够帮你解决MYSQL数据库MySQL事务一些总结所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/sjk/1161245.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-01
下一篇2022-06-01

发表评论

登录后才能评论

评论列表(0条)

    保存