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

有關TADOQuery, MSSQL-sql_variant, 2000 vs XP

尚未結案
melticemelt
一般會員


發表:22
回覆:29
積分:10
註冊:2002-10-01

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-11-23 09:33:43 IP:203.69.xxx.xxx 未訂閱
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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-11-24 08:14:13 IP:203.69.xxx.xxx 未訂閱
解決了 2000要灌MDAC就可以work了
系統時間:2024-05-18 12:42:37
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!