文档介绍:数据库原理及应用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