全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:3262
推到 Plurk!
推到 Facebook!

使用 DBX Master/Detail 在三層架構中的 Transaction 問題

答題得分者是:pcplayer99
danny
版主


發表:100
回覆:522
積分:595
註冊:2002-03-11

發送簡訊給我
#1 引用回覆 回覆 發表時間:2008-01-07 16:11:05 IP:203.79.xxx.xxx 訂閱
請教各位一個困擾我很久的問題, 我的環境及設定如下
1. BDS 2006, MIDAS, DBX, Firebird(Interbase)
2. Master/Detail 關係作在 ClientDataSet, 關係如下
Master <- Detail1 <- Detail2
獨立的 Table: SEQ, STOCK

其中 STOCK 是根據 Detail2 的內容作更新, SEQ 是根據 Master 的內容作更新
而 Detail1 & Detail2 有部份欄位是根據 Master 的內容作更新
請問這種架構, 要如何使用 Transaction 來維護資料的一置性(不考慮執行的效率) ?

謝謝各位 !!!
------
將問題盡快結案也是一種禮貌!
編輯記錄
danny 重新編輯於 2008-01-07 16:12:06, 註解 無‧
pcplayer99
尊榮會員


發表:146
回覆:790
積分:632
註冊:2003-01-21

發送簡訊給我
#2 引用回覆 回覆 發表時間:2008-02-20 15:19:19 IP:59.40.xxx.xxx 訂閱
你的问题描述不清晰。类似的问题,需要考虑的地方比较多,不知道你指的是哪种情况下。

如果是删除,最简单的办法,在 FireBird 里设置各 Table 之间的关系。

如果是 Master-Detail 表,由是通过在服务器端设计的 Master-Detail 架构拿到客户端的 ClientDataSet 来实现的,则只提交客户端的作为 Master 的 ClientDataSet 就可以了。

我的办法是在服务器端实现一个提交方法,假设我有3个表要同时提交,在该方法里启动 Transaction,3个表都提交成功才 Commit 它,否则就 RollBack.。然后在客户端需要提交的时候,调用那个方法,把3个 ClientDataSet.Delta 作为那个方法的参数传过去。
Mickey
版主


發表:77
回覆:1882
積分:1390
註冊:2002-12-11

發送簡訊給我
#3 引用回覆 回覆 發表時間:2008-06-26 11:39:00 IP:218.163.xxx.xxx 訂閱
可以考慮...用 NestedDataSet...讓 Master/Detail..."自然"包成一個 DataPacket

Transaction 就丟給 TDataSetProvider 去處理.
系統時間:2024-11-23 15:57:28
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!