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

有關applyupate後出現"cannot update read-only view"的錯誤訊息

缺席
mingking0947
一般會員


發表:30
回覆:32
積分:12
註冊:2005-07-08

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-10-09 11:16:26 IP:220.228.xxx.xxx 訂閱
各位前輩:
小弟在TClientDataSet元件做applyupdate時出現"cannot update read-only view"的錯誤訊息,相關設定如下:
一.架構:
1.DataModule1中有兩個元件: TSQLConnect TSQLDataSet(名為sqlSelect2)
2.FORM中有四個元件: TDataSetProvider (指定到sqlSelect2) TClientDataSet (名為cdsProg_Power) TDataSource TDBGrid
其中sqlSelect2的ResolveToDataSet = True
二.先create 一個名為V_AUTHORITY_UPDATE 的 view ,語法如下:
CREATE VIEW V_AUTHORITY_UPDATE( "INDEX", DEPARTMENT_INDEX, FORM_CAPTION, PROG_INDEX, )
AS select pp."INDEX",pp.DEPARTMENT_INDEX, pm.form_caption ,pp.PROG_INDEX,
from Prog_Power pp, prog_manager pm
where DEPARTMENT_INDEX = '1' and pp.prog_index = pm."INDEX";
三. 先做顯示.程式碼如下:
cdsProg_Power.Close;
DataModule1.sqlSelect2.Close;
DataModule1.sqlSelect2.CommandText := 'select * from V_AUTHORITY_UPDATE';
DataModule1.sqlSelect2.Open;
cdsProg_Power.open;
四,等使用者在dbgrid中更動後,將異動資料用applyupdate更新到interbase的資料庫中.程式碼如下:
cdsProg_Power.Post;
cdsProg_Power.ApplyUpdates(0);
五當更新時出現錯誤訊息如下:(用cdsProg_Power的ReconcileError去接)
"cannot update read-only view"

請問各位前輩,是否是那麼沒有設定好,或有其他改善方式可以由資料庫select兩張表格出來的資料更新回資料庫?
謝謝!!
ps.我記得有些文件中有說到view是可以更新含2張表格的異動資料回資料庫的.

P.D.
版主


發表:603
回覆:4038
積分:3874
註冊:2006-10-31

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-10-10 00:24:19 IP:61.67.xxx.xxx 未訂閱
1.如果我沒有記錯的話, View 是 readonly的結構,因為它是有點類似引用指定資料庫搭載特定的條件後,所產生的一個虛擬資料庫,此格式資料庫自動根據指定資料庫來源內容做異動,而你不可以對View的資料庫進行任何更新,請對你View中指定資料庫來源做異動,View會直接反應的
2.你可以把 VIEW 想成是一個條件式資料庫,這個資料庫是隨著主資料庫而自動產生變化的,VIEW雖然是虛擬的,但它仍然在資料表中佔有一個TABLE的實質位置
3.本篇比較適用放在資料庫中
編輯記錄
P.D. 重新編輯於 2007-10-10 00:24:55, 註解 無‧
P.D. 重新編輯於 2007-10-10 10:50:02, 註解 無‧
mingking0947
一般會員


發表:30
回覆:32
積分:12
註冊:2005-07-08

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-10-10 17:59:09 IP:122.123.xxx.xxx 訂閱
謝謝P.D版主的回覆.
經過測試的結果VIEW只可以更新單一資料表,若VIEW中有兩個以上的資料表就不能做更新的動作.
編輯記錄
mingking0947 重新編輯於 2007-10-10 18:00:28, 註解 無‧
系統時間:2024-11-23 17:46:43
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!