亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? uadodataaccess.pas

?? 抽象三層訪問數據庫示例
?? PAS
字號:
{*******************************************************}
{       軟件名稱: --通用--                              }
{       單元名稱: uADODataAccess.pas                    }
{       中文名稱: ADO數據訪問類                         }
{       單元描述:                                       }
{       創    建: SamonHua                              }
{       創建日期: 2007-12-18                            }
{       修    改: 參見VSS記錄                           }
{       版權所有 (C)2002-2007 深圳壹平臺信息技術有限公司}
{*******************************************************}
unit uADODataAccess;

interface

uses
  SysUtils, Classes, Variants, DB, DBClient, ADODB, uCommon, Provider,
  uDataAccess;

type
  TADODataAccess = class(TDataAccess)
  private
    FADOConnection: TADOConnection;
    FADOQuery: TADOQuery;
    FADOProc: TADOStoredProc;
    FADOExecQuery: TADOQuery;
    FADOUpdateQuery: TADOQuery;
    function GetADOConnection: TADOConnection;
    function GetADOQuery: TADOQuery;
    function GetADOProc: TADOStoredProc;
    function GetADOExecQuery: TADOQuery;
    function GetADOUpdateQuery: TADOQuery;
    property ADOConnection: TADOConnection read GetADOConnection;
    property ADOQuery: TADOQuery read GetADOQuery;
    property ADOProc: TADOStoredProc read GetADOProc;
    property ADOExecQuery: TADOQuery read GetADOExecQuery;
    property ADOUpdateQuery: TADOQuery read GetADOUpdateQuery;
  protected
    function GetQueryDataSet: TDataSet; override;
    function GetUpdateDataSet: TDataSet; override;
    function DoQueryData(ASQL: string): OleVariant; override;
  public
    function GetID(const TableName: string): string; override;
    function UpdateData(Data: OleVariant; const TableNameOrSQL, KeyFields: string): Boolean; override;
    function ExcuteSQL(const ASQL: string): Boolean; override;
    function GetBlobContent(const TableName, KeyFieldName, KeyFieldValue, BlobFieldName: string;
      BlobFieldContent: TStream): boolean; override;
    function UpdateBlobContent(const TableName, KeyFieldName, KeyFieldValue, BlobFieldName: string;
      BlobFieldContent: TStream): boolean; override;
    function BeginTrans: integer; override;
    procedure CommitTrans; override;
    procedure RollbackTrans; override;
    function InTransaction: boolean; override;
  end;

implementation

{ TADODataAccess }

function TADODataAccess.ExcuteSQL(const ASQL: string): Boolean;
begin
  Result := false;
  with ADOExecQuery do
  try
    Connection.BeginTrans;
    SQL.Text := ASQL;
    ExecSQL;
    Connection.CommitTrans;
    Close;
    Result := True;
  except
    on e: Exception do
    begin
      Connection.RollbackTrans;
      raise Exception.CreateFmt('執行SQL出錯,錯誤:%s', [e.Message]);
    end;
  end;
end;

function TADODataAccess.GetADOConnection: TADOConnection;
var
  strConnectionString: string;
begin
  if not Assigned(FADOConnection) then
  begin
    FADOConnection := TADOConnection.Create(Self);
    FADOConnection.LoginPrompt := false;
    if CompareText(DBType, 'MSSQL') = 0 then
    begin
      if DBUserName <> '' then
        strConnectionString := Format('Provider=SQLOLEDB.1;Password=%s;Persist Security Info=True;User ID=%s;Initial Catalog=%s;Data Source=%s',
          [DBPassword, DBUserName, DBName, DBHost])
      else//Windows身份認證
        strConnectionString := Format('Provider=SQLOLEDB.1;Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=%s;Data Source=%s',
          [DBName, DBHost]);
    end
    else if CompareText(DBType, 'Oracle') = 0 then
    begin
      if DBName = '' then
        DBName := DBHost;
      //默認使用MS提供的驅動程序,如果需要指定使用Oracle提供的驅動請使用參數"UseOracleDriver"
      if ParamExists(ExtendConfig, 'UseOracleDriver') then//oracle驅動
        strConnectionString := Format('Provider=OraOLEDB.Oracle.1;Password=%s;Persist Security Info=True;User ID=%s;Data Source=%s',
          [DBPassword, DBUserName, DBName])
      else
        strConnectionString := Format('Provider=MSDAORA;Password=%s;User ID=%s;Data Source=%s',
          [DBPassword, DBUserName, DBName]);
    end
    else if CompareText(DBType, 'MSAccess') = 0 then
    begin
      if DBName = '' then
        DBName := DBHost;
      strConnectionString := Format('Provider=Microsoft.Jet.OLEDB.4.0;Password=%s;User ID=%s;Data Source=%s;Persist Security Info=True',
        [DBPassword, DBUserName, DBName]);
    end
  end;
  Result := FADOConnection;
end;

function TADODataAccess.GetADOProc: TADOStoredProc;
begin
  if not Assigned(FADOProc) then
  begin
    FADOProc := TADOStoredProc.Create(Self);
    FADOProc.Connection := ADOConnection;
  end;
  Result := FADOProc;
end;

function TADODataAccess.GetADOQuery: TADOQuery;
begin
  if not Assigned(FADOQuery) then
  begin
    FADOQuery := TADOQuery.Create(Self);
    FADOQuery.Connection := ADOConnection;
  end;
  Result := FADOQuery;
end;

function TADODataAccess.GetQueryDataSet: TDataSet;
begin
  result := ADOQuery;
end;

function TADODataAccess.GetADOExecQuery: TADOQuery;
begin
  if not Assigned(FADOExecQuery) then
  begin
    FADOExecQuery := TADOQuery.Create(Self);
    FADOExecQuery.Connection := ADOConnection;
  end;
  Result := FADOExecQuery;
end;

function TADODataAccess.GetID(const TableName: string): string;
begin
  try
    with ADOProc do
    begin
      ProcedureName := 'get_id;1';
      Parameters.Clear;
      Parameters.CreateParameter('@RETURN_VALUE', ftInteger, pdReturnValue, 0, 0);
      Parameters.CreateParameter('@table_name', ftInteger, pdReturnValue, 0, TableName);
      Parameters.CreateParameter('@key_field', ftInteger, pdReturnValue, 0, '');
      Parameters.CreateParameter('@id', ftWideString, pdInputOutput, 18, '');
      ExecProc;
      Result := Parameters.ParamByName('@id').Value;
    end;
  except
    on e: Exception do
      raise Exception.CreateFmt('生成自動主鍵值失敗,錯誤:%s', [TableName]);
  end;
end;

function TADODataAccess.DoQueryData(ASQL: string): OleVariant;
begin
  with ADOQuery do
  begin
    SQL.Text := ASQL;
    try
      Open;
      Result := QueryDataProvider.Data;
      Close;
    except
      raise;
    end;
  end;
end;

function TADODataAccess.UpdateData(Data: OleVariant; const TableNameOrSQL,
  KeyFields: string): Boolean;
var
  strTableName, strKeyFields: string;
  i: integer;
  tmpField: TField;
  blnAutoTrans: boolean;
begin
  result := false;
  if VarIsNull(Data) or VarIsEmpty(Data) then
  begin
    Result := True;
    exit;
  end;
  if not VarIsArray(Data) then
    raise Exception.Create('傳入的數據集數據格式非法');
  blnAutoTrans := not InTransaction;
  if blnAutoTrans then
    BeginTrans; 
  try
    ADOUpdateQuery.Close;
    //UpdateDataProvider.DataSet := nil;//避免賦Data時出錯
    UpdateDataProvider.UpdateMode := upWhereAll;
    //簡單方式獲取表名
    if CompareText(Copy(Trim(TableNameOrSQL), 1, 6), 'select') = 0 then
    begin
      ADOUpdateQuery.SQL.Text := TableNameOrSQL;
      strTableName := Trim(Copy(TableNameOrSQL, pos('FROM', UpperCase(TableNameOrSQL)) + 4, MaxInt));
      if Pos(' ', strTableName) > 0 then
        strTableName := Copy(strTableName, 1, pos(' ', strTableName) - 1);
    end
    //建議采用傳表名的方式
    else
    begin
      ADOUpdateQuery.SQL.Text := Format('select * from %s where 1 = 2', [TableNameOrSQL]);
      strTableName := TableNameOrSQL;
    end;
    ADOUpdateQuery.Open;
    if not CheckSimpleTableUpdate(UpdateDataCDS, Data, KeyFields) then
      UpdateDataCDS.Data := Data;
    if UpdateDataCDS.ChangeCount = 0 then
    begin
      Result := True;
      exit;
    end;
    //設置字段更新方式
    if KeyFields <> '' then
    begin
      strKeyFields := StringReplace(KeyFields, ',', ';', [rfReplaceAll]);
      for i := 0 to UpdateDataCDS.FieldCount - 1 do
      begin
        //pfInUpdate, pfInWhere, pfInKey, pfHidden
        if ParamExists(strKeyFields, UpdateDataCDS.Fields[i].FieldName, true) then
          UpdateDataCDS.Fields[i].ProviderFlags := [pfInUpdate, pfInWhere, pfInKey]//ADOUpdateQuery.Fields[i].ProviderFlags + [pfInKey]
        else
          UpdateDataCDS.Fields[i].ProviderFlags := [pfInUpdate];//ADOUpdateQuery.Fields[i].ProviderFlags - [pfInWhere, pfInKey];
        ADOUpdateQuery.FieldByName(UpdateDataCDS.Fields[i].FieldName).ProviderFlags := UpdateDataCDS.Fields[i].ProviderFlags;
      end;
    end;
    try
      UpdateDataProvider.DataSet := ADOUpdateQuery;
      UpdateDataProvider.Options := UpdateDataProvider.Options +
        [poAllowCommandText, poCascadeUpdates];
      if KeyFields <> '' then
        UpdateDataProvider.UpdateMode := upWhereKeyOnly;
      result := UpdateDataCDS.ApplyUpdates(0) = 0;//更新數據至數據庫中
      if blnAutoTrans then
        CommitTrans;
    except
      on e: Exception do
      begin
        if blnAutoTrans then
          RollbackTrans;
        raise Exception.CreateFmt('更新數據失敗,錯誤:%s', [e.Message]);
      end;
    end;
  finally
    ADOUpdateQuery.Close;
    UpdateDataCDS.Close;
    if UpdateDataProvider.DataSet = nil then
      UpdateDataProvider.DataSet := ADOUpdateQuery;
  end;
end;

function TADODataAccess.GetUpdateDataSet: TDataSet;
begin
  result := ADOUpdateQuery;
end;

function TADODataAccess.GetADOUpdateQuery: TADOQuery;
begin
  if not Assigned(FADOUpdateQuery) then
  begin
    FADOUpdateQuery := TADOQuery.Create(Self);
    FADOUpdateQuery.Connection := ADOConnection;
  end;
  Result := FADOUpdateQuery;
end;

function TADODataAccess.BeginTrans: integer;
begin
  inherited;
  result := ADOConnection.BeginTrans;
end;

procedure TADODataAccess.CommitTrans;
begin
  inherited;
  if InTransaction then
    ADOConnection.CommitTrans;
end;

procedure TADODataAccess.RollbackTrans;
begin
  inherited;
  if InTransaction then
    ADOConnection.RollbackTrans;
end;

function TADODataAccess.InTransaction: boolean;
begin
  Result := ADOConnection.InTransaction;
end;

function TADODataAccess.GetBlobContent(const TableName, KeyFieldName,
  KeyFieldValue, BlobFieldName: string;
  BlobFieldContent: TStream): boolean;
var
  tmpCDS: TClientDataSet;
  strSQL, strKeyFieldList: string;
  i: integer;
begin
  Result := false;
  tmpCDS := TClientDataSet.Create(nil);
  try
    if Pos(';', KeyFieldName) > 0 then
    begin
      strKeyFieldList := '1 = 1';
      for i := 0 to SubStrCount(KeyFieldName) do
        strKeyFieldList := strKeyFieldList
          + Format(' and %s = %s', [CopySubStr(KeyFieldName, i), QuotedStr(CopySubStr(KeyFieldValue, i))]);
    end
    else
      strKeyFieldList := Format('%s = %s', [KeyFieldName, QuotedStr(KeyFieldValue)]);
    strSQL := Format('select %s from %s where %s',
      [BlobFieldName, TableName, strKeyFieldList]);
    tmpCDS.Data := GetData(strSQL);
    if tmpCDS.IsEmpty then
      exit;
    BlobFieldContent.Position := 0;
    TBlobField(tmpCDS.Fields[0]).SaveToStream(BlobFieldContent);
    Result := True;
  finally
    tmpCDS.Free;
  end;
end;

function TADODataAccess.UpdateBlobContent(const TableName, KeyFieldName,
  KeyFieldValue, BlobFieldName: string;
  BlobFieldContent: TStream): boolean;
var
  tmpCDS: TClientDataSet;
  strSQL, strKeyFieldList: string;
  i: integer;
begin
  Result := false;
  tmpCDS := TClientDataSet.Create(nil);
  try
    if Pos(';', KeyFieldName) > 0 then
    begin
      strKeyFieldList := '1 = 1';
      for i := 0 to SubStrCount(KeyFieldName) do
        strKeyFieldList := strKeyFieldList
          + Format(' and %s = %s', [CopySubStr(KeyFieldName, i), QuotedStr(CopySubStr(KeyFieldValue, i))]);
    end
    else
      strKeyFieldList := Format('%s = %s', [KeyFieldName, QuotedStr(KeyFieldValue)]);
    strSQL := Format('select %s from %s where %s',
      [BlobFieldName, TableName, strKeyFieldList]);
    tmpCDS.Data := GetData(strSQL);
    if tmpCDS.IsEmpty then
      exit;
    BlobFieldContent.Position := 0;
    tmpCDS.Edit;
    TBlobField(tmpCDS.Fields[0]).LoadFromStream(BlobFieldContent);
    tmpCDS.Post;
    Result := UpdateData(tmpCDS.Delta, TableName, KeyFieldName);
  finally
    tmpCDS.Free;
  end;
end;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www.亚洲人| 欧美日韩第一区日日骚| 91麻豆免费在线观看| 欧美裸体一区二区三区| 久久久久97国产精华液好用吗| 中文字幕欧美日韩一区| 国产亚洲午夜高清国产拍精品 | 欧美剧在线免费观看网站| 欧美一级生活片| 中文字幕在线观看一区| 日韩成人精品在线| 99在线精品视频| 日韩欧美一区电影| 亚洲精品成人a在线观看| 精品一区二区三区在线播放视频| 国产福利一区二区三区视频在线| 在线视频一区二区三| 国产亚洲精品久| 日韩国产精品久久久| www.亚洲免费av| 2020日本不卡一区二区视频| 亚洲一区二区在线观看视频| 国产精品影视在线观看| 日韩欧美视频一区| 亚洲欧美成aⅴ人在线观看| 久久精品二区亚洲w码| 欧美性一区二区| 中文字幕色av一区二区三区| 国产一区二区影院| 色94色欧美sute亚洲13| 国产精品污网站| 91首页免费视频| 日韩精品一区二区三区在线观看| 亚洲精品午夜久久久| 丰满岳乱妇一区二区三区| 久久久精品国产99久久精品芒果 | 丝瓜av网站精品一区二区| 99热99精品| 国产精品久久久久久福利一牛影视| 久久精品国产亚洲aⅴ| 欧美一区二区三区男人的天堂| 国产精品久久久久影院| 国产999精品久久久久久绿帽| 精品国产髙清在线看国产毛片| 午夜视频一区二区| 欧美日韩成人在线一区| 一区二区三区不卡视频在线观看 | 日韩免费电影一区| 日本伊人午夜精品| 欧美一区二视频| 理论电影国产精品| 精品欧美乱码久久久久久1区2区| 奇米影视在线99精品| 91精品国产高清一区二区三区| 亚洲已满18点击进入久久| 欧洲一区在线观看| 日韩一区欧美二区| 9191久久久久久久久久久| 日韩制服丝袜av| 日韩精品综合一本久道在线视频| 日韩av电影免费观看高清完整版| 日韩一区二区三区视频在线| 久久国产人妖系列| 欧美激情综合五月色丁香| 狠狠色狠狠色综合日日91app| 久久综合丝袜日本网| 成人精品在线视频观看| 樱花影视一区二区| 欧美精品 日韩| 狠狠色狠狠色综合系列| 国产午夜精品理论片a级大结局| 懂色av一区二区三区蜜臀| 国产精品视频yy9299一区| 色先锋aa成人| 偷偷要91色婷婷| 久久影视一区二区| 国产精品一区不卡| 亚洲免费在线播放| 欧美精品1区2区3区| 国产乱人伦偷精品视频不卡| 亚洲欧美日韩在线播放| 欧美日韩中文精品| 国产真实乱偷精品视频免| 国产精品区一区二区三| 欧美图片一区二区三区| 精品一区二区三区视频 | 高清免费成人av| 日韩不卡在线观看日韩不卡视频| 国产精品久久久久aaaa| 精品噜噜噜噜久久久久久久久试看 | 七七婷婷婷婷精品国产| 亚洲免费观看高清完整版在线观看熊 | 91在线视频免费观看| 国产九色精品成人porny| 日本女人一区二区三区| 亚洲久草在线视频| 中文字幕视频一区| 国产免费成人在线视频| 精品欧美黑人一区二区三区| 欧美精品免费视频| 精品视频1区2区3区| 99精品国产视频| 国产成人av一区二区三区在线 | 亚洲高清免费观看 | 91精品国产91久久久久久一区二区| 色欧美乱欧美15图片| 99re热这里只有精品免费视频| 国产精品中文字幕一区二区三区| 精品综合免费视频观看| 美女国产一区二区三区| 日本女优在线视频一区二区| 日韩国产精品久久| 蜜桃视频免费观看一区| 视频一区国产视频| 青椒成人免费视频| 精品中文字幕一区二区| 激情综合色播五月| 国产成人精品影视| k8久久久一区二区三区| 99re这里都是精品| 欧美在线影院一区二区| 欧美日韩精品久久久| 4438x成人网最大色成网站| 91精品国产综合久久国产大片| 欧美一区二区三区免费| 精品理论电影在线观看| 久久久久国产一区二区三区四区| 国产免费久久精品| 亚洲精品视频在线看| 亚洲第一狼人社区| 蜜桃精品视频在线观看| 国产一区二区三区日韩| 99久久国产综合精品女不卡| 欧美艳星brazzers| 日韩午夜激情av| 国产欧美视频一区二区| 亚洲欧美色图小说| 秋霞成人午夜伦在线观看| 国产精品影视在线| 色av一区二区| 日韩一区二区高清| 亚洲国产精品成人综合| 亚洲综合av网| 国产一区二区三区免费观看| 99久久99久久精品免费观看| 91精品国产入口在线| 国产精品五月天| 亚洲福利一二三区| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 免费观看成人鲁鲁鲁鲁鲁视频| 国产成人三级在线观看| 欧美在线观看视频一区二区| 欧美大片拔萝卜| 亚洲精品视频观看| 韩国三级在线一区| 欧美中文字幕一区二区三区| 久久影院午夜片一区| 亚洲一区二区三区三| 国内精品写真在线观看| 欧美性大战xxxxx久久久| 26uuu成人网一区二区三区| 亚洲女同ⅹxx女同tv| 精品一区二区在线播放| 欧美日韩激情在线| 国产精品乱码一区二区三区软件| 午夜精品福利一区二区三区蜜桃| 韩国av一区二区三区在线观看| 欧洲av在线精品| 国产精品久久久久永久免费观看 | 日韩免费视频线观看| 亚洲人成网站精品片在线观看 | 91 com成人网| 又紧又大又爽精品一区二区| 高清不卡在线观看av| 欧美一级免费观看| 夜夜嗨av一区二区三区四季av| 国产精品99久| 久久午夜电影网| 麻豆成人久久精品二区三区红| 色婷婷激情一区二区三区| 中文字幕国产一区| 国产一区二区免费看| 精品久久久网站| 日本vs亚洲vs韩国一区三区二区| 91浏览器打开| 亚洲欧美偷拍卡通变态| 99re视频精品| 自拍av一区二区三区| 国产suv一区二区三区88区| 精品日韩av一区二区| 日韩电影免费一区| 欧美一区二区在线不卡| 天天综合网天天综合色| 欧美日韩久久久一区| 亚洲最新在线观看| 91福利精品视频| 一区二区三区高清在线| 欧美日韩免费一区二区三区 | 不卡影院免费观看| 国产精品激情偷乱一区二区∴|