有關applyupate後出現"cannot update read-only view"的錯誤訊息 |
缺席
|
mingking0947
一般會員 發表:30 回覆:32 積分:12 註冊:2005-07-08 發送簡訊給我 |
各位前輩:
小弟在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 發送簡訊給我 |
1.如果我沒有記錯的話, View 是 readonly的結構,因為它是有點類似引用指定資料庫搭載特定的條件後,所產生的一個虛擬資料庫,此格式資料庫自動根據指定資料庫來源內容做異動,而你不可以對View的資料庫進行任何更新,請對你View中指定資料庫來源做異動,View會直接反應的
2.你可以把 VIEW 想成是一個條件式資料庫,這個資料庫是隨著主資料庫而自動產生變化的,VIEW雖然是虛擬的,但它仍然在資料表中佔有一個TABLE的實質位置 3.本篇比較適用放在資料庫中 |
mingking0947
一般會員 發表:30 回覆:32 積分:12 註冊:2005-07-08 發送簡訊給我 |
謝謝P.D版主的回覆.
經過測試的結果VIEW只可以更新單一資料表,若VIEW中有兩個以上的資料表就不能做更新的動作.
編輯記錄
mingking0947 重新編輯於 2007-10-10 18:00:28, 註解 無‧
|
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |