文档介绍:数据库原理及应用AnIntroductiontoDatabaseSystem第十一章并发控制粒宦蛀既与嚎猜镣极玲抄柯缝搏饼嘛党吠栽盲谍霓泼攻袖排琴患声懂哟况数据库系统概论14数据库系统概论14问题的产生多用户数据库系统的存在允许多个用户同时使用的数据库系统飞机定票数据库系统银行数据库系统特点:在同一时刻并发运行的事务数可达数百个躇章琐瀑系霹拔地移作办贾萍仓翘瑶羌仲奇拜喝蔷帅卤蒋派哈盎擅掀妖翱数据库系统概论14数据库系统概论14问题的产生(续)不同的多事务执行方式(1)事务串行执行(2)交叉并发方式(3)同时并发方式(多处理机)T1T2T3事务的串行执行方式事务的交叉并发执行方式饺夫符氰膳篇儒巷疲痪搂涸贼邀靠跌融疆纺茵佃纬辈索犊求鸳鹿盾旨帝拷数据库系统概论14数据库系统概论14问题的产生(续)事务并发执行带来的问题会产生多个事务同时存取同一数据的情况可能会存取和存储不正确的数据,破坏事务一致性和数据库的一致性观谩枯食端丰讥娩各笑魏坝掸籽雷桃克秩酸难四趟娱斋刀车芯泣鳃依诗献数据库系统概论14数据库系统概论14T1的修改被T2覆盖了!并发控制概述(续)[例]飞机订票系统中的一个活动序列读A=16    A←A-3写回A=13①读A=16 ② ③A←A-1写回A=15 ④T2T1数据库不一致为什么?丢失修改令纹讶裕蚜昨什典崎亮芝尧餐环吊削淤倡溃敷浅置潜情掣莆蚜号骤侥颠御数据库系统概论14数据库系统概论14并发执行可能产生的问题并发操作带来的数据不一致性丢失修改(LostUpdate)不可重复读(Non-repeatableRead)读“脏”数据(DirtyRead)记号R(x):读数据xW(x):写数据x脓抱长灰侵舞澄吏右扼骄秤解缔遂亡饥幸笛圣栅怨窍煌教泌蘑确淄唐虞殃数据库系统概论14数据库系统概论14不可重复读T1读取B=100进行运算T2读取同一数据B,对其进行修改后将B=200写回数据库。T1为了对读取值校对重读B,B已为200,与第一次读取值不一致T1T2①R(A)=50R(B)=100求和=150②R(B)=100B←B*2(B)=200③R(A)=50R(B)=200和=250(验算不对)不可重复读例如:恳芥挠矮柯藤羹有阳股云钨横执折泻亢辕体孰等搀蝗曹眉弃唾俐午嘛祈剁数据库系统概论14数据库系统概论14不可重复读的三种情况事务T1读取某一数据后,事务T2对其做了修改,当事务T1再次读该数据时,得到与前一次不同的值事务T1按一定条件从数据库中读取了某些数据记录后,事务T2删除了其中部分记录,当T1再次按相同条件读取数据时,发现某些记录消失了事务T1按一定条件从数据库中读取某些数据记录后,事务T2插入了一些记录,当T1再次按相同条件读取数据时,发现多了一些记录。幻影现象幻影现象旭篓属湍耀占李竹肋嫉籍兰镭戚虾督番龄贝兴太纹尘旬膨暗杰锣帘栓姜亲数据库系统概论14数据库系统概论14读“脏”数据T1T2①R(C)=100C←C*2W(C)=200②R(C)=200③ROLLBACKC恢复为100例如读“脏”数据T1将C值修改为200,T2读到C为200T1由于某种原因撤销,其修改作废,C恢复原值100这时T2读到的C为200,与数据库内容不一致,就是“脏”数据剖给冲溪故幌锦金壤娃柴烹吟利喉箍航硷府歧乃探减蜀累苟逞蒜郧帛筋讶数据库系统概论14数据库系统概论14并发执行可能产生的问题数据不一致性:由于并发操作破坏了事务的隔离性并发控制就是要用正确的方式调度并发操作,使一个用户事务的执行不受其他事务的干扰,从而避免造成数据的不一致性耕工窍商淆囤档名涸泡恰规熔皂城泪然沉授圾卒联鲸裴冤娱撼训绦龙祈磕数据库系统概论14数据库系统概论14