在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
只是单纯知道事物的隔离级别,但是从未操作过 今日操作一次。 脏读(Drity Read):某个事务已更新一份数据,另一个事务在此时读取了同一份数据,由于某些原因,前一个RollBack了操作,则后一个事务所读取的数据就会是不正确的。 不可重复读(Non-repeatable read):在一个事务的两次查询之中数据不一致,这可能是两次查询过程中间插入了一个事务更新的原有的数据。 幻读(Phantom Read):在一个事务的两次查询中数据笔数不一致,例如有一个事务查询了几列(Row)数据,而另一个事务却在此时插入了新的几列数据,先前的事务在接下来的查询中,就会发现有几列数据是它先前所没有的。 mysql的4种隔离级别read uncommitted : 读取尚未提交的数据 :哪个问题都不能解决
创建数据表:create table shuzhi ( id mediumint(8) primary key, name varchar(30), shuzhi mediumint(10) ); alter table shuzhi engine=innodb; insert into shuzhi values(1,'aa',1000); insert into shuzhi values(2,'bb',2000); insert into shuzhi values(3,'cc',3000); insert into shuzhi values(4,'dd',4000); insert into shuzhi values(5,'ee',5000); insert into shuzhi values(6,'ff',6000); insert into shuzhi values(7,'gg',7000); insert into shuzhi values(8,'hh',8000); 开始测试事物的4种隔离级别 第一种:read uncommitted (读未提交) 设置隔离级别#查询当前的隔离级别 SELECT @@tx_isolation #设置隔离级别 set session transaction isolation level [隔离级别] set session transaction isolation level read uncommitted 先开启第一个进程 先开启事物 暂不进行查询 窗口1 start transaction; 再开启第二个进程(终端) 窗口2 start transaction; update shuzhi set shuzhi='8888' where id=7; 去数据库查询发现id=7的值还是7000值并没改变 再去窗口1中查询这个记录 窗口1 start transaction; select * from shuzhi where id=7 发现读到的数据是窗口2中为提交的数据 并不是7000 到此这篇关于mysql隔离级别详解及示例的文章就介绍到这了,更多相关mysql隔离级别内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论