有關TADOQuery, MSSQL-sql_variant, 2000 vs XP |
尚未結案
|
melticemelt
一般會員 發表:22 回覆:29 積分:10 註冊:2002-10-01 發送簡訊給我 |
Msg欄位是sql_variant
sl->Strings[4]是用UTF8Encode的WideString
Server端以TADOQuery寫入MSSQL程式碼如下
在XP下完全沒問題
可是在2000下一樣可以正常執行
但是卻寫入一堆怪怪的東西
編譯的環境是XPsp1,BCB6
編譯後執行檔用installshield包起來拿到2000安裝依然出現此問題
難道說要在2000 compile才行嗎?
try { ADOQueryMsg->Close(); ADOQueryMsg->SQL->Clear(); ADOQueryMsg->Parameters->Clear(); ADOQueryMsg->SQL->Add( "Insert into GBUMsg (Flag, InputDate, InputTime, Auth, UserName, Msg) Values ( :Flag, :InputDate, :InputTime, :Auth, :UserName, :Msg)" );//end SQL ADOQueryMsg->Parameters->ParamByName("Flag")->Value = sl->Strings[1];//Flag ShortDateFormat = "yyyymmdd"; ADOQueryMsg->Parameters->ParamByName("InputDate")->Value = DateToStr(Now()); LongTimeFormat = "hhnnss"; ADOQueryMsg->Parameters->ParamByName("InputTime")->Value = TimeToStr(Now()); ADOQueryMsg->Parameters->ParamByName("Auth")->Value = sl->Strings[2];//Auth ADOQueryMsg->Parameters->ParamByName("UserName")->Value = sl->Strings[3];//Username ADOQueryMsg->Parameters->ParamByName("Msg")->Value = UTF8Decode(sl->Strings[4]); if (!ADOQueryMsg->Prepared) ADOQueryMsg->Prepared = true; ADOQueryMsg->ExecSQL(); ADOQueryMsg->Close(); }catch(...) { // } |
melticemelt
一般會員 發表:22 回覆:29 積分:10 註冊:2002-10-01 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |