网络版问题之三(临时表) |
答題得分者是:kevinguo
|
ntjrr
高階會員 發表:240 回覆:312 積分:110 註冊:2005-04-24 發送簡訊給我 |
在单机版中,所做的收费流程如下:每收完一个品种,就将该品种的名称,规格,单价,数量等存入临时表中,如果误收了,就可以在临时表中删除掉,然后合计应收也是从临时表中算出来的,当收费结束按确定时,所有的临时表中的记录将存到正式表中,并从库存表中的物品库存量减去临时表中的相应物品的销售数量。优点,临时表中记录少,操作效率高。改成网络版后就有了问题了,你这边在收费,其它客户机也在收费,那么这个临时表的记录不可能独占使用了,那么整个的收费就都要乱套了。也许有人会说,在一台客户机上收费时,那么另一台就不让他收费(这样就不写临时表了)但本软件就是为了收费而设计的,试想着十个收费窗口,有一个窗口在收时其它九个等,那么也就见不到网络版的优势了,那么这个问题如何处理呢?谢谢!
------
我的编程起步于ktop,我将永远支持ktop |
kevinguo
初階會員 發表:1 回覆:31 積分:31 註冊:2002-11-20 發送簡訊給我 |
ntjrr兄,您好: 你可以使用ADOConnection元件的transaction功能,應該可以達到你的需求,用法如下
把ADOTable的Connection設為ADOConnection
ADOConnection.BeginTrans; //開始一個新的交易
ADOTable.edit;
ADOTableFieldName.asstring:='xxxxxxxx'
ADOTable.post;
........
.......
ADOConnection.CommitTrans;
//下了CommitTrans才會把交易間的資料異動更新到資料庫,CommitTrans之前,不管你做了什麼異動,都只會暫存 發表人 -
|
ntjrr
高階會員 發表:240 回覆:312 積分:110 註冊:2005-04-24 發送簡訊給我 |
|
kevinguo
初階會員 發表:1 回覆:31 積分:31 註冊:2002-11-20 發送簡訊給我 |
|
ntjrr
高階會員 發表:240 回覆:312 積分:110 註冊:2005-04-24 發送簡訊給我 |
|
kevinguo
初階會員 發表:1 回覆:31 積分:31 註冊:2002-11-20 發送簡訊給我 |
|
ntjrr
高階會員 發表:240 回覆:312 積分:110 註冊:2005-04-24 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |