麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Delphi > 正文

Delphi7中存儲unicode的BUG

2019-11-18 18:00:49
字體:
來源:轉載
供稿:網友
 

Delphi7中存儲unicodeBUG

近日,在用delphi7unicode的程序時發現了這樣一個問題,就是使用TADOCommand組件執行sql語句時,如果sql語句中有unicode字符,存儲在數據庫里會出現亂碼,使用TTntADOQuery也是一樣(使用參數方式不會出現亂碼,這里只討論純sql的方式)。但是TADOCommand本身是支持widestring的呀,CommandText屬性也是widestring類型的,為什么會出現這個問題呢?我試著改變TADOCommand的幾個屬性值,發現了一個怪現象,只要把ParamCheck屬性置為false就可以正常的存儲unicode字符,而置為true時就出現亂碼。為什么會出現這種情況?這個屬性看起來和unicode本身沒有任何關系,究竟是什么原因導致了亂碼的發生呢?我通過研究TADOCommand所在的adodb.pas文件,發現了問題的所在,我們看一下bug所在的過程:

PRocedure TADOCommand.AssignCommandText(const Value: WideString; Loading: Boolean);

  procedure InitParameters;

  var

    I: Integer;

    List: TParameters;

    NativeCommand: string;

  begin

    List := TParameters.Create(Self, TParameter);

    try

      NativeCommand := List.ParseSQL(Value, True);

      { Preserve existing values }

      List.AssignValues(Parameters);

      CommandObject.CommandText := NativeCommand;

      if not Loading and (Assigned(Connection) or (ConnectionString <> '')) then

      begin

        try

          SetConnectionFlag(cfParameters, True);

          try

            { Retrieve additional parameter info from the server if supported }

            Parameters.InternalRefresh;

            { Use additional parameter info from server to initialize our list }

            if Parameters.Count = List.Count then

              for I := 0 to List.Count - 1 do

              begin

                List[I].DataType := Parameters[I].DataType;

                List[I].Size := Parameters[I].Size;

                List[I].NumericScale := Parameters[I].NumericScale;

                List[I].Precision := Parameters[I].Precision;

                List[I].Direction := Parameters[I].Direction;

                List[I].Attributes := Parameters[I].Attributes;

              end

          finally

            SetConnectionFlag(cfParameters, False);

          end;

        except

          { Ignore error if server cannot provide parameter info }

        end;

        if List.Count > 0 then

          Parameters.Assign(List);

      end;

    finally

      List.Free;

    end;

  end;

begin

  if (CommandType = cmdText) and (Value <> '') and ParamCheck then

    InitParameters

  else

  begin

    CommandObject.CommandText := Value;

    if not Loading then Parameters.Clear;

  end;

end;

看看這一條語句:

if (CommandType = cmdText) and (Value <> '') and ParamCheck then

    InitParameters

也就是當ParamChecktrue時,會執行InitParameters過程,我們看看這個InitParameters過程中發生了什么:

首先它定義個一個變量:NativeCommand: string;,注意,是stirng不是widestring我們接著往下看:

NativeCommand := List.ParseSQL(Value, True);

      { Preserve existing values }

      List.AssignValues(Parameters);

CommandObject.CommandText := NativeCommand;

在這里,Valuewidestring類型的,而List.ParseSQL返回的是string類型的,同時NativeCommand也是string類型的,就這樣,一個好好的widestring的變量被放到了string類型的變量當中,然后又把NativeCommand賦給了CommandObject.CommandText,因此導致了CommandObject.CommandText并沒有得到應該賦給它的widesting值,這也就最終導致了存儲unicode時亂碼的發生。

       解決方法也很簡單,(如果你不愿意修改delphi源程序的話)只需要把ParamCheck置為false就可以了(delphi默認把ParamCheck置為true)。



上一篇:DELPHI加注冊表自啟動的最簡單代碼

下一篇:Delphi數據庫應用程序中常見錯誤

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

主站蜘蛛池模板: omofun 动漫在线观看 | 精品一区二区电影 | 久久亚洲网 | 国产成人精品区一区二区不卡 | 久久精品亚洲成在人线av网址 | 久久亚洲成人网 | 青青国产在线视频 | 久久一级 | 成人在线视频黄色 | 黄色大片高清 | teensexhd| 国产午夜亚洲精品理论片大丰影院 | 欧美特一级片 | 美女毛片儿 | 国产精品热| 日本成年免费网站 | 色中色在线播放 | 91成人免费视频 | 国产精品免费观在线 | 男人的天堂视频网站 | 美国一级黄色毛片 | 免费观看又色又爽又黄的崩锅 | a免费视频 | 久久精品一区二区三区四区五区 | 日本不卡一区二区三区在线观看 | 欧美精品亚洲人成在线观看 | 亚洲成人福利在线 | 久久亚洲线观看视频 | 日韩欧美中文字幕视频 | 欧洲精品久久久久69精品 | 久久久久久久一区 | 美女被免费网站在线软件 | 国产女同疯狂激烈互摸 | 午夜色视频在线观看 | 亚洲精中文字幕二区三区 | 久久综合久久综合久久 | xxxx8| 国产一区二区在线免费播放 | 9999视频| 国产一级大片在线观看 | 一级黄色免费大片 |