| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 975 人关注过本帖
标题:VFP9:两个以上用户共同编辑一个表时出现的锁定和解锁问题,请指正......
只看楼主 加入收藏
fytao
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2016-4-25
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:1 
VFP9:两个以上用户共同编辑一个表时出现的锁定和解锁问题,请指正......
msso_h 父表
msso_d:子表
cNosaveText=不能保存,其他人正在使用

例:A用户正在编辑记录1,B用户正在编辑记录2,
     这时A用户编辑完按“保存”会发现“不能保存,其他人正在使用”
     B用户编辑完按“保存”也会“不能保存,其他人正在使用”
    结果死循环,只能撤销。
   
******************************下面是“保存”的代码*********************************
If This.goto_txtemploy()
Else
    Return .F.
Endif
curarea=sele()
Begin  TRANSACTION
If THIS.modifyflag
    =this.revdata()
    Sele msso_h
    Replace grand_amt WITH THISFORM.pageframe1.page1.txtgrand_amt.VALUE
    Select msso_d
    Delete IN msso_d FOR empty(stock_code)
Else
    lastno = AUTONO("msso_h","msso_id")
    If  typeesc
        Rollback
        Return
    Endif
    Select msso_h
    If Rlock()
        Repl msso_h.msso_id WITH lastno,;
             grand_amt WITH THISFORM.pageframe1.page1.txtgrand_amt.VALUE
        Sele msso_d
        GO RECNO()
        SCAN For alltrim(msso_id)="NEW"
            REPL msso_id WITH  lastno FOR UPPER(ALLTRIM(msso_id))="NEW"
            Delete IN msso_d FOR empty(stock_code)
            DELETE IN msso_d for msso_d.qty_l+msso_d.qty_s=0            
        ENDSCAN   
        UNLOCK ALL
    Else
        Rollback
        = MESSAGEBOX(cMessageText,64,'警告!')
        Sele (curarea)
        Return
    endif
endif   
saveOK = tableupdate(1,.T.,'msso_h')
if saveOK
    saveOK = tableupdate(1,.T.,'msso_d')
endif
IF saveOK
    End Transaction
    This.lallowedits=.T.
    This.lallowdelete=.T.
    This.lallownew=.T.
    This.CLOSABLE=.T.
    IF .NOT.THIS.modifyflag
        WAIT WIND  "存盘成功,单号是:"+lastno NOWAIT
    ELSE
        WAIT WIND "存盘成功...  " NOWAIT
    ENDIF
    SELE msso_h
    UNLOCK ALL
    THIS.REFRESH()
    this.pageframe1.page1.cmdfocuscontrol.SETFOCUS()   
else
    ROLLBACK
    Sele (curarea)
    =MESSAGEBOX(CHR(13)+cNosaveText,0+0+0,"提示")
    Return
Endif
*****************************下面是“编辑”的代码************************
Sele msso_h
If filed.or.finished
    =messagebox("这张单已经完成,不能修改!",0+0+0,"提示")
    Return
Endif
a=recno()
GO a
IF Rlock()
    Sele * from msso_d into cursor tmpmsso where msso_id=msso_h.msso_id
    This.lAllowEdits=.f.
    This.lAllowdelete=.f.
    This.lAllownew=.f.
    This.closable=.f.
    This.modifyflag=.t.
    Thisform.pageframe1.ACTIVEPAGE = 1
    Thisform.pageframe1.page2.ENABLED = .F.
    Thisform.pageframe1.page1.grdlineitems.setfocus()
Else
    = MESSAGEBOX('其他用户正在使用,请稍候尝试!',64,'警告!')
    Sele msso_h
    Return         
Endif   
搜索更多相关主题的帖子: 用户 记录 
2017-05-31 22:46
hu9jj
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:红土地
等 级:贵宾
威 望:400
帖 子:11773
专家分:43421
注 册:2006-5-13
收藏
得分:20 
将表或者当前记录先锁定,编辑后就可以保存了,保存之后再解锁,其他人就可以正常使用了。在帮助文件中对“共享”数据有更详细的解释。

活到老,学到老!http://www.(该域名已经被ISP盗卖了)E-mail:hu-jj@
2017-06-01 08:11
快速回复:VFP9:两个以上用户共同编辑一个表时出现的锁定和解锁问题,请指正... ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016944 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved