融海咨询informix_4gl教材第二十八章行锁:FORUPDATE游标.doc_第1页
融海咨询informix_4gl教材第二十八章行锁:FORUPDATE游标.doc_第2页
融海咨询informix_4gl教材第二十八章行锁:FORUPDATE游标.doc_第3页
融海咨询informix_4gl教材第二十八章行锁:FORUPDATE游标.doc_第4页
融海咨询informix_4gl教材第二十八章行锁:FORUPDATE游标.doc_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第二十八章行锁:FOR UPDATE游标本章讲解带游标声明的FOR UPDATE 怎样锁住一行。当四个用户同时想修改同一行时该怎么办?你只有两种选择:l l 让他们同时修改。在这种情况下,最后释放该行的用户所作的修改将被保留下来。l l 为第一个请求修改的用户锁住该行,其它想修改该行的用户要等到第一个用户完成。这种方式,其它用户可以查询该行,但不能修改。第二种方式(即为第一个用户锁住该行)是最佳方式。若用如上图一样的Form,用户将先查询,然后用Next和Perious选项找某一行,当用户选定一行进行修改时,才用加锁。删除一行是否也加锁?回答是肯定的。不能在某一用户删除行时还让其它用户对这行进行修改。有些程序员锁住取到的所有行。这是不对的,当用户只是浏览时没必要加锁。若对于FOR UPDATE游标的每次向上、向下移动一行都锁住,在用户选择向上、向下选项时都得对锁进行检测,这样会无端增加代码量。在上图的代码中,说明了当行修改时,在哪儿加锁:当用户通过Form修改行时才需要给它加锁。这是为了保证这个用户修改完成前,其它用户不能对该行进行修改。释放锁和加锁同样重要。在用户对行修改完成后就应释放锁,这由程序员来完成。在上图例子中,在行修改完成后立即就释放了锁。当用户删除一行时,因为没对它做修改,所以不用锁很久,只需在DELETE语句执行时锁住即可。当用户选择修改或删除选项时,怎么能知道锁哪行呢?回答很简单,只用锁住当前显示的行即可。但怎么知道这是哪行呢?在大多数情况下,用户选择查询选项,查询选项作以下工作:l l 让用输入查询条件l l 为取数声明SCROLL游标l l 把第一行数据值放到程序变量记录中用户每次选择Next或Previous都向程序变量中送一行数据。全局程序变量中含有表的主键(Customer表中是Customer.customer_num),所以若用户修改了屏幕上的一行,则只用锁住Customer表中Customer.customer_num = gr_customer.customer_num的行。由于是主键,所以只锁住一行。用FOR UPDATE游标锁住数据库表的一行,FOR UPDATE包括四个游标语句。l l DECLARE语句:用于建立SELECT语句的标识。FOR UPDATE选项用于告诉游标在取出一行时加锁,但FOR UPDATA游标不能用SCROLL选项。l l OPEN语句:用于查看SELECT符号并为SELECT语句申请内存。l l FETCH语句:用于从数据库表中检索一行。若游标声明为FOR UPDATE的,FETCH语句就把这行锁住,直到取另一行数据或执行CLOSE游标语句才释放锁。l l CLOSE语句:用于把当前锁住的行打开。在上图例子中,加入了一个新函数updel_init。其中所有游标语句都是模块范围的,且DECLARE语句必须放在其它游标语句之前。updel_init函数用于声明FOR UPDATE游标,且在程序开头处调用。用FOR UPDATE游标可以节省执行时间。不要因为DECLARE语句中用了gr_customer.customer_num变量而糊涂,这个变量值要在OPEN和FETCH语句执行时才

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论