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

TAdoDataSet 寫入 Access 備忘欄位都變空白

缺席
cancer
高階會員


發表:58
回覆:319
積分:190
註冊:2004-07-31

發送簡訊給我
#1 引用回覆 回覆 發表時間:2011-02-18 20:06:24 IP:220.128.xxx.xxx 未訂閱
請問各位先進,我在 Delphi 2006 .net,用 TAdoDataSet 讀取 Sql Server,把資料寫入到 Access 檔的備忘(memo)欄位,再用這個 Access 檔的資料,用 TAdoDataSet 讀出來,轉入另一台 Sql Server,算是主機之間的資料交換。
但讀入 Access 後,所有備忘欄位都是空白的,試過這樣

1.dsAccess.Fields[i].Value := dsArt..Fields[i].Value ;
2.dsAccess.Fields[i].AsVariant := dsArt..Fields[i].AsVariant ;
3.dsAccess.Fields[i].AsString := dsArt..Fields[i].AsString ;
4.dsAccess.Fields[i].Assign(dsArt..Fields[i]);
5.dsAccess.Fields[i].AsString := '123';

全部都沒用,備忘欄位一樣是空白的。後來我在轉出的檔案裡,在備忘欄位中手工輸入文字,用 TAdoDataSet 讀出來轉入 Sql Server,手工輸入的文字可以轉入 Sql Server,表示 TAdoDataSet 可以讀取 Access 備忘欄位,但寫入備忘欄位卻全都是空白,有誰有類似經驗並知道如何解決?或者,可以提供主機之間資料交換的更好方法,不然,用 xml 是不是比較好?
編輯記錄
cancer 重新編輯於 2011-02-18 05:07:34, 註解 無‧
cancer
高階會員


發表:58
回覆:319
積分:190
註冊:2004-07-31

發送簡訊給我
#2 引用回覆 回覆 發表時間:2011-02-21 10:30:24 IP:220.128.xxx.xxx 未訂閱
各位好,我找到原因了,因為我是用 Delphi 2006 開發 .net 程式,Delphi.net 程式的 Memo 欄位,必須建立永久欄位(Persistant Field),不可以使用動態建立的欄位,否則,Memo 存取時,不是程式出錯,就是內容空白,非常麻煩,讀取速度也比 Win32 慢很多,沒事的話,用 Win32 寫就好,新版 Delphi 的 Win32 一樣支援 Unicode。
cancer
高階會員


發表:58
回覆:319
積分:190
註冊:2004-07-31

發送簡訊給我
#3 引用回覆 回覆 發表時間:2011-02-23 11:01:09 IP:211.75.xxx.xxx 未訂閱
使用 persistant field 很麻煩,每次修改資料表欄位長度,相關的每一支程式、每一支 dll 都要打開,按兩下 DataSet,刪除該欄位,再重新加入該欄位,以反應最新的欄位資訊,我的案子有大約 300 支 dll,十幾支輔助小程式,誰知道哪些 dll 用到哪些資料表?就算知道,一支一支拿出來改,煩死了,用 Dynamic Field 好多了,欄位長度增加,不用修改程式。
系統時間:2024-04-24 8:11:19
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!