通行证: 用户 密码 域名空间  下载中心 社区论坛 信息公告 MY小屋
联系我们
设为首页
加入收藏

 

QQ,ASP,PHP,JSP,XML,SQL,.Net,编程 程序 网页图象 建站经验 私服
首页 | 新闻资讯 | 编程开发 | 网页设计 | 图形图象 | 网络媒体 | 网站模板 | 数 据 库 | 投稿
论坛 | 操作系统 | 系统优化 | 网络安全 | 黑客技术 | 硬件学堂 | 硬件报价 | 服 务 器 | 地图
专题 | 应用软件 | 聊天通讯 | Q Q 专栏 | 建站经验 | 在线工具 | 站长Club | 注 册 表 | 旧版
社会 | 游戏娱乐 | 设计欣赏 | 疑难解答 | 社区论坛 | 韩国素材 | 素材图库 | 广告服务 | 服务
当前位置:首页>>编程开发>>VB编程>>正文 新版上线![旧版]
注:打开慢时请稍等

页面锁定--多客户环境下VB数据库编程之(5)

http://www.iyit.net  日期:2006-5-22 17:00:16  来源:网络转载   点击:
参加讨论从理想的角度来说,如果能对记录进行锁定,则会给多用户程序带来极大的灵活性。然而遗憾的是,Microsoft Jet引擎不支持真正的记录锁定,而是使用页面锁定。页面锁定只锁定包含当前正在编辑的记录的页,Microsoft Jet进行访问和锁定的页的大小为2K(2048个字节)。在使用页面锁定时,其他用户可以读取锁定页中的数据,但不能对数据进行修改。在这种锁定方案中,每次将锁定多个记录,锁定的记录的个数取决于每个记录的大小。例如,如果每个记录的长度为230个字节,则每次只能锁定9个记录;而如果记录的长度为30个字节,则每次可锁定68个记录。

锁定模式。页面锁定分为两种模式,即保守式锁定和开放式锁定,它确定了Microsoft Jet如何对数据进行锁定。当编写在页面级别上锁定数据的应用程序时,必须确定要使用哪种锁定模式。页面锁定可以通过两种方法来设置,即LockEdits属性和OpenRecordset方法中的lockedit5参数。

1.用LockEdits 属性指定锁定模式。锁定模式可以通过LockEdits属性来指定。该属性可用于各种Recordset对象,包括动态集、快照、表及动态类型的Recordset对象。LockEdits属性是一个布尔值,当把该值设置为True(缺省)时,将对记录集进行保守式锁定,即在执行Edit方法时锁定2K的页面:如果把该属性设置为False,则对记录集进行开放式锁定,即在执行UPdate之前不锁定要更新的记录所在的2K页面。如下面的例子:

Dim rstTemP As ReCordset
……
rstTemp.LockEdits=True

说明:a.锁定页面后,其它用户不能对正在编辑的记录所在页面进行修改,但可以读取锁定页中的数据。在其它用户锁定页面后,如果再把LockEdits属性设置为True,则会出错。b.如果把LockEdits属性设置为False,且其它用户已锁定页面,则其后的用户在使用Update时将会出错。c.当与Microsoft连接的ODBC数据源一起操作时,LockEdits属性被设置为False,即开放式锁定。

2.用OpenRecordset方法指定锁定模式。我们已多次使用过OpenRecordset方法,该方法的格式如下:

Set recordset=object.OpenRecordset(type,options,lockedits)

其中第三个参数,即lockedits,用来指定锁定模式或以只读方式打开记录集。该参数可以取以下5种值:

(1)dbReadOnly:以只读方式打开记录集。注意,在options参数中也可以使用dbReadOnly,但不能同时使用,否则会产生错误。

(2)dbPessimistic:用保守式锁定模式打开记录集,一旦使用Edit方法,将立即锁定正在编辑的记录所在的页面,直到执行Update方法后才释放对该页面的锁定。

(3)dbOptimistic:用保守式锁定模式打开记录集,在执行Update方法前不锁定正在编辑的记录所在的页面。

(4)dbOptimisticValue: 基于行值使用开放式并发(仅ODBCDirect工作区)。
(5)dbOptimisticBatch:允许开放式更新(仅ODBCDirect工作区)。

保守式锁定和开放式锁定。

1).保守式锁定。保守式锁定也称为悲观锁定。设置保守式锁定后,只要对某个记录使用Edit方法,就自动锁定该记录所在的页面,直到显式地提交或取消这个记录的变更(例如执行UPdate方法)后,才释放对该页面的锁定,并把数据写入文件中。保守式锁定是Recordset对象的缺省锁定方式。保守式锁定的主要优点是,获得锁定之后,只要记录还被锁定着,就可以防止其它用户修改该记录中的数据,因此不会发生任何锁定冲突。另外,由于一个用户不能在另一个用户开始编辑记录之后改变它,所以,保守式锁定也是保证应用程序读取最新数据的唯一方法。保守式锁定的缺点是,在编辑和锁定该记录的过程中,包含该记录的整个页面都被锁定。当锁定时间较长时,可能会给其它用户造成不必要的麻烦。例如,用户设置保守式锁定后,开始编辑一个记录,并在记录被锁定期间离开了计算机(例如出去办事),这不仅锁定了用户正在编辑的记录,而且锁定驻留在该锁定页面内的其它记录,使其它用户长时间内无法编辑页面中的记录。

2).开放式锁定。开放式锁定也称乐观锁定。使用开放式锁定时,MicrosoftJet引擎仅在试图用Update方法提交记录变更时才锁定页面,完成更新操作后立即释放对页面的锁定。由于锁定仅在应用程序试图提交变更时发生,因此能使锁定的时间最短,使其它用户只在锁定生效的较短时间内不能访问该页面。这是开放式锁定的主要优点。开放式锁定的缺点是:当用户正在编辑记录时,不能保证更新是否会成功。如果另一个用户改变了第一个用户正在编辑的记录,那么依赖于开放式锁定的更新将会失败。例如,假定张三和李四正在编辑同一个记录,张三开始以开放式锁定编辑某个客户记录。由于张三使用的是开放式锁定,并没有真正锁定记录,所以不能禁止李四试图编辑相同的记录。在李四编辑相同的客户记录时,他不知道张三正在编辑该记录,并且也没有看到最新的数据。当张三试图在李四编辑相同的客户记录时存储他的变更,就会产生一个错误。对于大多数数据库应用程序来说,可能要选择开放式锁定,因为其它用户修改或删除本人正在使用的记录的可能性要小于试图访问已被锁定的页面上记录的可能性。但是,如果某个应用程序中有多个用户同时访问和编辑记录,则应使用保守式锁定,以确保在执行编辑期间记录不被其他人修改。在这种情况下,应注意不要使记录锁定的时间过长。

3).释放锁定。如前所述,在执行Update方法后,将自动释放页面锁定。但是,释放记录锁定是一种后台进程,有时候,其它操作发生得很快,以至于数据库来不及处理该进程。如果正在开发一个数据输入密集型的应用程序,则可能需要暂停应用程序的处理,这可以通过Microsoft Jet数据库引擎的Idle方法来完成。Idle方法挂起数据处理,启用Microsoft Jet数据库引擎执行其它操作,诸如内存优化或内存页超时等(仅Microsoft Jet工作区)。该方法用于DBEngine对象,格式如下:

DBEngine.Idle[dbRefreshCachel

在多用户环境中,用Idle方法可以使Microsoft Jet数据库引擎执行后台任务。在一般情况下,仅当没有任何操作(包括移动鼠标)发生时,才释放读锁定并更新本地动态集类型的Recordset对象中的数据。如果定时地使用Idle方法,则Microsoft Jet可以释放不必要的读锁定,以捕获后台处理任务。Idle方法有一个可选的参数,即dbRefreshCache,如果使用该参数,则可强制挂起写入.MDB文件,并用.MDB文件中的最新数据刷新内存。

编辑:黑鹰 [发送给好友] [打印本页] [关闭窗口] [返回顶部]
上一篇:共享数据的锁定--多客户环境下VB数据库编程之(3)
下一篇:实现页面锁定的一个具体例子--多客户环境下VB数据库编程之(6)
转载请注明来源:www.iyit.net
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。

 相关文章
VB两种操作Access数据库方法的比较 用VB备份和恢复SQL Server数据库的方法 VB程序如何访问数据库
VB程序如何连接数据库 VB+Oracle 9i如何构建开发和运行的环境 VB游戏攻略
在VBScript中使用类(一) 在VBScript中使用类(二) 在VBScript中使用类(三)
在VBScript中使用类(四) RC4经典加密算法VB版本代码 在asp中通过vbs类实现rsa加密与解密
ASP VBScript 函数速查表 清空iis log 中自己登录ip的vbs EJB系列教程之一(JBuilder4+IAS41+Vbj4
用VB编写标准CGI程序 用ASP、VB和XML建立互联网应用程序 使用XML+VBS技术在ASP中实现报表的打印
vbs类生成xml文件 Delphi使用VB6编写的ActiveX控件??? Delphi使用VB编写的ActiveX控件全攻略
如何把VC++代码转换成VB代码? VB与VC通信初探(二) VB与VC通信初探(一)
最新更新 热点排行 推荐新闻
Visual Basic 5.0中实现视频画中画
保存列表框内容为文本文件
Visual Basic 概述
Visual Basic 概述二
Visual Basic 概念
长期使用中型Access数据库的一点经验
Access数据库及其基本操作
两个未公开的ACCESS方法的使用技巧
如何确定有多少人登陆数据库?
提高拆分数据库在网上运行、编辑的速度
能否编译mdb文件到exe文件?
创建一个空数据库
隐藏 Access 窗口
获取Windows / System / Temp 目录路径
Access数据库开发技巧(一)
Visual Basic 概述
快速初始化Variant和String类型数组
VB中APP对象及其应用
Visual Basic 概述二
Visual Basic使用技巧
优秀公益广告作品欣赏(8)
java数据类型转换
Windows XP专业版IIS连接数的更改
QQ最新版下载 2006 beta2 体验新感受 
优秀公益广告作品欣赏(7)
Office2007简体中文版浮出水面 美图抢
WEB服务器配置全攻略(三)
优秀公益广告作品欣赏(6)
优秀公益广告作品欣赏(4)
优秀公益广告作品欣赏(1)
直接编辑VB中网格控制项的两种方法
硬盘分区消失,解决方法!
传统计算机病毒传播能力破坏性在提高
内存为何有“两面性”
AMD水货盒装CPU识别方法
IP地址资源2012年枯竭 部署IPv6很紧迫
古老问题有新解:世上先有鸡蛋后有鸡
Dreamweaver MX 2004从零开始(1)
利用CSS改善网站可访问性
如何让MM的脸通透可人
msn8.0下载
 友情链接
设置首 页 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyrights © 2004-2006 iYiT.Net All Rights Reserved.
网站合作、广告联系QQ:147007642、466949678
易特网络技术 点击这里给我发消息