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

如何針對 Delta 去產生 SQL 語法

答題得分者是:liang19787
Jasonwong
版主


發表:49
回覆:931
積分:581
註冊:2006-10-27

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-06-23 14:16:49 IP:59.120.xxx.xxx 未訂閱
由於 LEFT JOIN 的關係, 常會下載跟後端無關的欄位, 導致無法 UPDATE, 所以才會想說自己去產生 UPDATE 的 SQL 語法, 請問要如何做呢 ? 謝謝 -- 把手握緊,裡面什麼也沒有 把手鬆開,你擁有的是一切
------
聰明的人,喜歡猜心;雖然每次都猜對了,卻失去了自己的心
傻氣的人,喜歡給心;雖然每次都被笑了,卻得到了別人的心
pcplayer99
尊榮會員


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-06-24 22:06:38 IP:202.105.xxx.xxx 未訂閱
引言: 由於 LEFT JOIN 的關係, 常會下載跟後端無關的欄位, 導致無法 UPDATE, 所以才會想說自己去產生 UPDATE 的 SQL 語法, 請問要如何做呢 ? 謝謝 -- 把手握緊,裡面什麼也沒有 把手鬆開,你擁有的是一切
我以前做过这样的程式。细节已经忘记了。大概的意思是: 拿一个ClientDataSet1.Data:=Delta, 然后,你可以用一个for: for i:=0 to ClientDataSet1.FieldCount-1 do begin end; 在里面把每个 Field 的名字和Value(包括 OldValue 和 NewValue)读到,自己把它组成一句SQL了。
pcplayer99
尊榮會員


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

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-06-24 22:10:15 IP:202.105.xxx.xxx 未訂閱
还有,你可以在 AppServer 里的DataSetProvider的BeforeApplyUpdates和BeforeUpdateRecord这两个事件里写上代码,按前面的说法来分解Delta
Jasonwong
版主


發表:49
回覆:931
積分:581
註冊:2006-10-27

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-06-27 19:47:38 IP:59.120.xxx.xxx 未訂閱
引言: 还有,你可以在 AppServer 里的DataSetProvider的BeforeApplyUpdates和BeforeUpdateRecord这两个事件里写上代码,按前面的说法来分解Delta
謝謝回應 -- 把手握緊,裡面什麼也沒有 把手鬆開,你擁有的是一切
------
聰明的人,喜歡猜心;雖然每次都猜對了,卻失去了自己的心
傻氣的人,喜歡給心;雖然每次都被笑了,卻得到了別人的心
liang19787
一般會員


發表:0
回覆:1
積分:5
註冊:2005-07-03

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-07-03 15:47:28 IP:219.132.xxx.xxx 未訂閱
其實很簡單 想想看, 依據Delta自動產生的SQL語法 它是怎麼樣自動產生的呢?ProviderFlags 只要將無關欄位ProviderFlags標簽的[pfinupdate,pfinwhere],pfinkey,pfinhidden] 全部設為FALSE 比在 AppServer 里的DataSetProvider的BeforeApplyUpdates和BeforeUpdateRecord写代码,分解Delta方便的多 如 采購單主表 需要客戶表的ID 展示采購單時要展示客戶名稱 可以采用采購單主表 LEFT JOIN 客戶表 取得客戶表NAME UPDATE時 Field客戶名稱 的ProviderFlags設為FALSE 就不會產生客戶名稱更新的語法
系統時間:2024-04-20 22:32:50
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!