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

关于Recordset 序列化后 无法UpdateBatch的问题

缺席
纯洁的兔仔
一般會員


發表:1
回覆:0
積分:0
註冊:2013-12-18

發送簡訊給我
#1 引用回覆 回覆 發表時間:2013-12-18 11:26:50 IP:60.191.xxx.xxx 訂閱

如題:
ADOQuery1.Recordset序列化,傳遞后在反序列化給ADOQuery2.Recordset
對ADOQuery2.Recordset的值修改後,序列化并傳遞反序列化給ADOQuery3. Recordset
發現一個問題ADOQuery3執行的UpdateBatch無法更新到數據庫
ADOQuery1,2,3的屬性
Active:=True;
LockType:= ltBatchOptimistic;
CursorLocation:= clUseClient;
CursorType的:= ctStatic;
後面又做了幾個測試
測試1
ADOQuery1.Recordset直接獲取數據修改後的UpdateBatch可以更新到數據庫
ADOQuery2.Recordset直接獲取數據修改後的UpdateBatch也可以更新到數據庫
ADOQuery3.Recordset直接獲取數據修改後的UpdateBatch也可以更新到數據庫
測試2
ADOQuery1.Recordset直接獲取數據,然後修改ADOQuery1.Recordset內容,后序列化ADOQuery1.Recordset,在反序列化賦值給ADOQuery2.Recordset
直接
ADOQuery2.UpdateBatch;
無法更新到數據庫

測試3
ADOQuery1.Recordset直接獲取數據,后序列化ADOQuery1.Recordset,在反序列化賦值給ADOQuery2.Recordset,然後修改ADOQuery2.Recordset內容
直接
ADOQuery2.UpdateBatch;
無法更新到數據庫
測試3
ADOQuery1.Recordset直接獲取數據,然後修改Recordset內容后序列化ADOQuery1.Recordset,在反序列化賦值給ADOQuery2.Recordset
ADODataSet2.SaveToFile('a.xml');
ADODataSet2.LoadFromFile('a.xml');
然後ADOQuery2.UpdateBatch可以直接更新到數據庫

檢索了很多資料也沒查出來到底什麼原因導致的,還請給指點下吶.
另外不打算用midas或者是datasnap
編輯記錄
纯洁的兔仔 重新編輯於 2013-12-18 11:28:14, 註解 無‧
系統時間:2017-12-19 2:35:55
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!