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

Delphi 6 和 Delphi 2010 運用 MSSQL 2005 的問題

尚未結案
nashbig2
一般會員


發表:2
回覆:1
積分:0
註冊:2011-01-27

發送簡訊給我
#1 引用回覆 回覆 發表時間:2011-07-07 09:56:34 IP:113.28.xxx.xxx 訂閱
 各位大大好!

我最近用 Delphi 6 和 Delphi 2010 修改一個學長留下的程式.
資料庫 是 MSSQL 2005

但是我發現當我寫一個 String 入資料庫內的 NVARCHAR(30) 時, 系統自動填入空格補滿

Parameters : ADODB.TParameters;

Parameters.ParamByName('USER_NAME').Value := 'CHENDONG';

結果在 MSSQL 裡變成
'CHENDONG '

請問有大大遇過這問題嗎? 請幫忙, 謝謝!
cancer
高階會員


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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2011-07-08 09:10:47 IP:220.128.xxx.xxx 未訂閱
可能是 parameter 的問題,我從不使用 parameter,都是用
AdoQuery1.Sql.Text := Format('insert into tablename .....', [...]);
這樣的語法,但大部份情形,我都少用 insert 或 update,而是用讀取零筆,再 Append 的方式,這樣可以程式較好維護。用 insert, update 之類的,您要知道欄位是不是 unicode 型態,用 DataSet.Append,Delphi 會幫您處理 Unicode 的問題。

AdoQuery1.Sql.Text := 'select top 0 * from TableName';
AdoQuery1.Open;
AdoQuery1.Append;
........
AdoQuery1.Post;
AdoQuery1.Close;
編輯記錄
cancer 重新編輯於 2011-07-07 19:12:28, 註解 無‧
nashbig2
一般會員


發表:2
回覆:1
積分:0
註冊:2011-01-27

發送簡訊給我
#3 引用回覆 回覆 發表時間:2011-07-08 15:35:51 IP:113.28.xxx.xxx 訂閱
謝謝大大, 我試下你的方法! ^_^

===================引 用 cancer 文 章===================
可能是 parameter 的問題,我從不使用 parameter,都是用
AdoQuery1.Sql.Text := Format('insert into tablename .....', [...]);
這樣的語法,但大部份情形,我都少用 insert 或 update,而是用讀取零筆,再 Append 的方式,這樣可以程式較好維護。用 insert, update 之類的,您要知道欄位是不是 unicode 型態,用 DataSet.Append,Delphi 會幫您處理 Unicode 的問題。

AdoQuery1.Sql.Text := 'select top 0 *from TableName';
AdoQuery1.Open;
AdoQuery1.Append;
........
AdoQuery1.Post;
AdoQuery1.Close;
系統時間:2024-03-30 0:03:04
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!