- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第13章 多用户操作
第13章 多用户操作 13.1 多用户简介 13.2 多用户 FoxPro 的加锁和 出错处理13.3 死锁的预防 13.1 多 用 户 简 介 13.1.1 数据的一致性和正确性 假定, 分处于两个网络工作站上的两程序甲和乙同时使用某库文件A。 甲打开A库文件后, 对其中的数据进行修改; 乙用户打开A库文件后, 只是使用其中的数据(即不进行修改操作)。 再进一步假定, 甲、 乙两用户同时都对同一库文件A进行修改。 此时, 情况更复杂了。 当两用户修改结束后, 谁也无法确定, 库文件更新的数据中, 哪些是正确的, 哪些是错误的; 哪些数据最终是仅由甲修改的, 哪些数据最终是乙修改的, 哪些数据是甲乙双方修改的结果。 也即, 在这种情况下, 连数据的正确性都无法保证。 加锁可以保证数据的一致性和正确性。 13.1.2 加锁, 共享, 冲突与死锁 所谓加锁(Locking)就是对库文件加锁(File Locking)。 当用户甲对库文件A加锁后, 其他用户都不能再使用此库文件。 上述的加锁法虽然可以保证库文件数据的一致性和正确性, 但却不能使多个用户同时使用同一个库文件, 即破坏了共享。 当用户甲要使用某库文件数据时(不修改), 如果不在乎数据是否一致, 他并不需要对库文件A进行加锁; 但若他要求数据必须一致, 那么必须给库文件A加锁。 加锁虽然可以保证数据的一致性和正确性, 但加锁也带来了两个新问题: 冲突和死锁。 冲突(Collision)。 当用户甲对库文件加锁, 不允许其他用户使用此库文件后, 用户乙企图打开此库文件, 就发生了冲突。 或者, 当用户甲对库文件加锁, 不允许其他用户修改此库文件后, 用户乙企图修改此库文件, 也会发生冲突。 死锁一般在多库文件操作时发生。 用户甲对库文件A加锁, 不允许其他用户使用, 然后, 准备使用库文件B的数据; 但库文件B已被用户乙加锁, 不允许其他用户使用, 且用户乙也准备使用库文件A的数据。 13.2 多用户 FoxPro 的加锁和出错处理 13.2.1 多用户 FoxPro 的加锁 1. 独占加锁 在打开库文件的同时, 对库文件进行的加锁为独占加锁。 独占加锁是最严厉的加锁。 一个库文件被独占加锁后, 只有加锁用户可以使用该库文件, 其他用户无权打开此库文件, 更谈不上修改, 使用此库文件了。 (1) 独占加锁法。 FoxPro提供了两种独占加锁的方法。 ① 使用SET EXCLUSIVE命令, 命令格式为: SET EXCLUSIVE ON/OFF 执行了SET EXCLUSIVE ON命令后, 系统将处于EXCLUSIVE ON状态。 在此状态下, 执行USE命令打开库文件时, 若无特殊声明, 被打开的库文件都是独占加锁的。 但是, 该命令执行以前, 未独占打开的库文件, 仍保持不独占加锁的特性(共享特性)。 执行了SET EXCLUSIVE OFF命令后, 系统即处于EXCLUSIVE OFF状态。 在此状态下, 利用USE命令打开库文件时, 若无特殊声明, 打开的库文件是不独占加锁的。 但是, 此命令执行前, 已独占加锁的库文件, 仍保持独占加锁的特性。 观察下列程序段: SET EXCLUSIVE ON SELECT 1 USE 职工 SET EXCLUSIVE OFF SELECT B USE 工资 上述程序若能执行成功, 职工.DBF库文件独占加锁, 工资 .DBF未独占加锁(可共享)。 SET EXCLUSIVE的初始默认值为ON。 ② 打开库文件时, 声明独占加锁。 利用USE命令打开库文件时, 若带有子句: EXCLUSIVE 则打开的库文件是独占加锁的。 即使刚执行过SET EXCL
您可能关注的文档
最近下载
- 《应用文写作》高职完整全套教学课件.pdf
- 人教版二年级上册数学全册教学设计(配2025年秋新版教材).docx
- 路灯维修工考试题库单选题100道及答案.docx VIP
- TDZJN 80-2022 数据中心用锂离子电池设备产品技术标准.docx
- 2025年教科版一年级《科学》上册全册教案 .pdf VIP
- 唱天瑶 课件接力版音乐五年级上册(共11张PPT)(含音频+视频).pptx VIP
- 数字化驱动下的智慧家庭医生服务报告.pdf VIP
- [工程科技]MODFLOW用户手册中文版.doc
- 苏教版小学一年级数学下学期综合检测试卷 附解析.pdf VIP
- 矿山排水工培训课件视频.pptx VIP
文档评论(0)