線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:3160
推到 Plurk!
推到 Facebook!

3層架構的錯誤訊息

答題得分者是:Jasonwong
Ivy489
一般會員


發表:1
回覆:1
積分:0
註冊:2006-08-04

發送簡訊給我
#1 引用回覆 回覆 發表時間:2006-08-04 13:27:00 IP:220.134.xxx.xxx 訂閱

我所規劃的架構如下
1.在AP Server端-->ADOConnection , ADOQuery , DataSetProvider
2.在Client端-->DCOMConnection,ClientDataSet
ClientDataSet.CommandText所放的SQL指令是由2個table所join出來的
例:select A.cna,B.* from cust A, orderM B where A.cno=B.cno

我的問題是:

如果我把DataSetProvider的UpdateMode設成upWhereAll,
透過SQL Profiler可以看到將資料寫回資料庫的指令,
但是卻出現一個錯誤的訊息"無效的資料行名稱'cna'",
我知道這是因為要更新的table是orderM,而在orderM中無cna欄位的原因,
且我有把ClientDataSet的cna欄位的ProviderFlags全設成false,所以為何會有這個錯誤訊息呢?

如果我把DataSetProvider的UpdateMode設成upWhereKeyOnly,
出現另一個錯誤訊息"Unable to find record. No key specified",
因為在orderM中的PK是ordno,且我有把ClientDataSet的ordno欄位的ProviderFlags中的pfInUpdate,pfInWhere,pfInKey
都設成true,又為何會有這個錯誤訊息呢

是我有那裡少設嗎??

Jasonwong
版主


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2006-08-04 16:14:25 IP:211.78.xxx.xxx 未訂閱

你設 ClientDataSet ProviderFlags 沒有用

你必須去設 ADOueryProviderFlags 才有用

------
聰明的人,喜歡猜心;雖然每次都猜對了,卻失去了自己的心
傻氣的人,喜歡給心;雖然每次都被笑了,卻得到了別人的心
Ivy489
一般會員


發表:1
回覆:1
積分:0
註冊:2006-08-04

發送簡訊給我
#3 引用回覆 回覆 發表時間:2006-08-04 17:24:11 IP:220.134.xxx.xxx 訂閱
感謝Jasonwong幫我解答,
我已經將ProviderFlags改設在ADOuery
但現在出現另一個錯誤訊息是"Field'ordno' cannot be modified.",
問題是資料確實有寫回資料庫,而這個訊息是我那個部份的設定有誤呢???
Jasonwong
版主


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

發送簡訊給我
#4 引用回覆 回覆 發表時間:2006-08-13 12:29:10 IP:61.57.xxx.xxx 未訂閱

"Field'ordno' cannot be modified."

檢查一下 ORDNO 這個欄位吧

------
聰明的人,喜歡猜心;雖然每次都猜對了,卻失去了自己的心
傻氣的人,喜歡給心;雖然每次都被笑了,卻得到了別人的心
系統時間:2024-04-26 0:44:48
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!