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

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

?? fr_xxxquery.pas

?? 工廠進銷存系統,包括權限管理
?? PAS
字號:

{******************************************}
{                                          }
{     FastReport v2.4 - XXX components     }
{             Query component              }
{                                          }
{ Copyright (c) 1998-2001 by Tzyganenko A. }
{                                          }
{******************************************}

unit FR_XXXQuery;

interface

{$I FR.inc}

uses
  Windows, Messages, SysUtils, Classes, Graphics, StdCtrls, Controls, Forms,
  Menus, Dialogs, FR_Class, FR_Pars, DB, UXXXQuery, FR_XXXTable, FR_DBUtils;

type
  TfrXXXQuery = class(TfrXXXDataSet)
  private
    FQuery: TXXXQuery;
    FParams: TfrVariables;
    procedure SQLEditor(Sender: TObject);
    procedure ParamsEditor(Sender: TObject);
    procedure ReadParams(Stream: TStream);
    procedure WriteParams(Stream: TStream);
    function GetParamKind(Index: Integer): TfrParamKind;
    procedure SetParamKind(Index: Integer; Value: TfrParamKind);
    function GetParamText(Index: Integer): String;
    procedure SetParamText(Index: Integer; Value: String);
    procedure BeforeOpenQuery(DataSet: TDataSet);
  protected
    procedure SetPropValue(Index: String; Value: Variant); override;
    function GetPropValue(Index: String): Variant; override;
    function DoMethod(MethodName: String; Par1, Par2, Par3: Variant): Variant; override;
  public
    constructor Create; override;
    destructor Destroy; override;
    procedure LoadFromStream(Stream: TStream); override;
    procedure SaveToStream(Stream: TStream); override;
    procedure DefineProperties; override;
    procedure Loaded; override;
    property Query: TXXXQuery read FQuery;
    property ParamKind[Index: Integer]: TfrParamKind read GetParamKind write SetParamKind;
    property ParamText[Index: Integer]: String read GetParamText write SetParamText;
  end;


implementation

uses
  FR_Utils, FR_Const, FR_DBSQLEdit, FR_XXXQueryParam
{$IFDEF QBUILDER}
, FR_XXXQB, QBuilder
{$ENDIF}
{$IFDEF Delphi6}
, Variants
{$ENDIF};


{ TfrXXXQuery }

constructor TfrXXXQuery.Create;
begin
  inherited Create;
  FQuery := TXXXQuery.Create(frDialogForm);
  FQuery.BeforeOpen := BeforeOpenQuery;
  FDataSet := FQuery;
  FDataSource.DataSet := FDataSet;

  FParams := TfrVariables.Create;

  Component := FQuery;
  BaseName := 'Query';
  Bmp.LoadFromResourceName(hInstance, 'FR_XXXQUERY');
end;

destructor TfrXXXQuery.Destroy;
begin
  FParams.Free;
  inherited Destroy;
end;

procedure TfrXXXQuery.DefineProperties;

  function GetMasterSource: String;
  var
    i: Integer;
    sl: TStringList;
  begin
    Result := '';
    sl := TStringList.Create;
    frGetComponents(FQuery.Owner, TDataSet, sl, FQuery);
    sl.Sort;
    for i := 0 to sl.Count - 1 do
      Result := Result + sl[i] + ';';
    sl.Free;
  end;

begin
  inherited DefineProperties;
  AddEnumProperty('DataSource', GetMasterSource, [Null]);
  AddProperty('Params', [frdtHasEditor], ParamsEditor);
  AddProperty('SQL', [frdtHasEditor], SQLEditor);
  AddProperty('SQL.Count', [], nil);
end;

procedure TfrXXXQuery.SetPropValue(Index: String; Value: Variant);
var
  d: TDataset;
begin
  inherited SetPropValue(Index, Value);
  Index := AnsiUpperCase(Index);
  if Index = 'DATASOURCE' then
  begin
    d := frFindComponent(FQuery.Owner, Value) as TDataSet;
    FQuery.DataSource := frGetDataSource(FQuery.Owner, d);
  end
  else if Index = 'SQL' then
    FQuery.SQL.Text := Value
end;

function TfrXXXQuery.GetPropValue(Index: String): Variant;
begin
  Index := AnsiUpperCase(Index);
  Result := inherited GetPropValue(Index);
  if Result <> Null then Exit;
  if Index = 'DATASOURCE' then
    Result := frGetDataSetName(FQuery.Owner, FQuery.DataSource)
  else if Index = 'SQL' then
    Result := FQuery.SQL.Text
  else if Index = 'SQL.COUNT' then
    Result := FQuery.SQL.Count;
end;

function TfrXXXQuery.DoMethod(MethodName: String; Par1, Par2, Par3: Variant): Variant;
begin
  Result := inherited DoMethod(MethodName, Par1, Par2, Par3);
  if Result = Null then
    Result := LinesMethod(FQuery.SQL, MethodName, 'SQL', Par1, Par2, Par3);
  if MethodName = 'EXECSQL' then
    FQuery.ExecSQL
end;

procedure TfrXXXQuery.LoadFromStream(Stream: TStream);
var
  s: String;
begin
  FFixupList.Clear;
  inherited LoadFromStream(Stream);
  FQuery.DatabaseName := frReadString(Stream);
  FQuery.Filter := frReadString(Stream);
  FQuery.Filtered := Trim(FQuery.Filter) <> '';
  s := frReadString(Stream);
  FFixupList['DataSource'] := s;
  Prop['DataSource'] := FFixupList['DataSource'];
  frReadMemo(Stream, FQuery.SQL);

  FFixupList['Active'] := frReadBoolean(Stream);
  ReadFields(Stream);
  ReadParams(Stream);
  try
    FQuery.Active := FFixupList['Active'];
  except;
  end;
end;

procedure TfrXXXQuery.SaveToStream(Stream: TStream);
begin
  LVersion := 1;
  inherited SaveToStream(Stream);
  frWriteString(Stream, FQuery.DatabaseName);
  frWriteString(Stream, FQuery.Filter);
  frWriteString(Stream, Prop['DataSource']);
  frWriteMemo(Stream, FQuery.SQL);
  frWriteBoolean(Stream, FQuery.Active);
  WriteFields(Stream);
  WriteParams(Stream);
end;

procedure TfrXXXQuery.Loaded;
begin
  Prop['DataSource'] := FFixupList['DataSource'];
  inherited Loaded;
end;

procedure TfrXXXQuery.SQLEditor(Sender: TObject);
begin
  with TfrDBSQLEditorForm.Create(nil) do
  begin
    Query := FQuery;
    M1.Lines.Assign(FQuery.SQL);
{$IFDEF QBUILDER}
    QBEngine := TfrQBXXXEngine.Create(nil);
    TfrQBXXXEngine(QBEngine).Query := FQuery;
    QBEngine.DatabaseName := Prop['DatabaseName'];
{$ENDIF}
    if (ShowModal = mrOk) and ((Restrictions and frrfDontModify) = 0) then
    begin
      FQuery.SQL := M1.Lines;
      frDesigner.Modified := True;
    end;
{$IFDEF QBUILDER}
    QBEngine.Free;
{$ENDIF}
    Free;
  end;
end;

procedure TfrXXXQuery.ParamsEditor(Sender: TObject);
var
  Params: TParams;
  ParamValues: TfrVariables;
begin
  if FQuery.Params.Count > 0 then
  begin
    Params := TParams.Create;
    Params.Assign(FQuery.Params);
    ParamValues := TfrVariables.Create;
    ParamValues.Assign(FParams);
    with TfrXXXParamsForm.Create(nil) do
    begin
      QueryComp := Self;
      Query := FQuery;
      Caption := Self.Name + ' ' + frLoadStr(SParams);
      if ShowModal = mrOk then
        frDesigner.Modified := True
      else
      begin
        FQuery.Params.Assign(Params);
        FParams.Assign(ParamValues);
      end;
      Free;
    end;
    Params.Free;
    ParamValues.Free;
  end;
end;

function TfrXXXQuery.GetParamKind(Index: Integer): TfrParamKind;
begin
  Result := pkValue;
  if not FQuery.Params[Index].Bound then
    Result := pkAssignFromMaster;
end;

procedure TfrXXXQuery.SetParamKind(Index: Integer; Value: TfrParamKind);
begin
  if Value = pkAssignFromMaster then
  begin
    FQuery.Params[Index].Bound := False;
    FParams.Delete(FParams.IndexOf(FQuery.Params[Index].Name));
  end
  else
  begin
    FQuery.Params[Index].Clear;
    FQuery.Params[Index].Bound := True;
    FParams[FQuery.Params[Index].Name] := '';
  end;
end;

function TfrXXXQuery.GetParamText(Index: Integer): String;
begin
  Result := '';
  if ParamKind[Index] = pkValue then
    Result := FParams[FQuery.Params[Index].Name];
end;

procedure TfrXXXQuery.SetParamText(Index: Integer; Value: String);
begin
  if ParamKind[Index] = pkValue then
    FParams[FQuery.Params[Index].Name] := Value;
end;

procedure TfrXXXQuery.ReadParams(Stream: TStream);
var
  i: Integer;
  w, n: Word;
begin
  Stream.Read(n, 2);
  for i := 0 to n - 1 do
  with FQuery.Params[i] do
  begin
    Stream.Read(w, 2);
    DataType := ParamTypes[w];
    Stream.Read(w, 2);
    ParamKind[i] := TfrParamKind(w);
    ParamText[i] := frReadString(Stream);
  end;
end;

procedure TfrXXXQuery.WriteParams(Stream: TStream);
var
  i: Integer;
  w: Word;
begin
  w := FQuery.Params.Count;
  Stream.Write(w, 2);
  for i := 0 to FQuery.Params.Count - 1 do
  with FQuery.Params[i] do
  begin
    for w := 0 to 10 do
      if DataType = ParamTypes[w] then
        break;
    Stream.Write(w, 2);
    w := Word(ParamKind[i]);
    Stream.Write(w, 2);
    frWriteString(Stream, ParamText[i]);
  end;
end;

procedure TfrXXXQuery.BeforeOpenQuery(DataSet: TDataSet);
var
  i: Integer;
  SaveView: TfrView;
  SavePage: TfrPage;
  SaveBand: TfrBand;

  function DefParamValue(Param: TParam): String;
  begin
    if Param.DataType in [ftDate, ftDateTime] then
      Result := '01.01.00'
    else if Param.DataType = ftTime then
      Result := '00:00'
    else
      Result := '0';
  end;

begin
  SaveView := CurView;
  CurView := nil;
  SavePage := CurPage;
  CurPage := ParentPage;
  SaveBand := CurBand;
  CurBand := nil;
  i := 0;
  try
    while i < FQuery.Params.Count do
    begin
      if ParamKind[i] = pkValue then
        if DocMode = dmPrinting then
          FQuery.Params[i].Text := frParser.Calc(ParamText[i]) else
          FQuery.Params[i].Text := DefParamValue(FQuery.Params[i]);
      Inc(i);
    end;
  except
    Memo.Clear;
    Memo.Add(ParamText[i]);
    CurView := Self;
    raise;
  end;
  CurView := SaveView;
  CurPage := SavePage;
  CurBand := SaveBand;
end;


var
  Bmp: TBitmap;

initialization
  Bmp := TBitmap.Create;
  Bmp.LoadFromResourceName(hInstance, 'FR_XXXQUERYCONTROL');
  frRegisterControl(TfrXXXQuery, Bmp, IntToStr(SInsertQuery));

finalization
  frUnRegisterObject(TfrXXXQuery);
  Bmp.Free;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久成人av少妇免费| 综合电影一区二区三区 | 国产日韩综合av| 欧美一区二区在线观看| 欧美性感一区二区三区| 欧美色视频在线| 欧美性大战久久久久久久 | 麻豆91精品91久久久的内涵| 调教+趴+乳夹+国产+精品| 亚洲国产三级在线| 午夜精品久久久久久久蜜桃app | 久久精品国产色蜜蜜麻豆| 美国十次综合导航| 国产精一品亚洲二区在线视频| 国产毛片精品视频| 不卡的电影网站| 91久久久免费一区二区| 51午夜精品国产| 久久日韩精品一区二区五区| 国产精品网站一区| 亚洲欧美日韩国产综合| 午夜精品久久久| 免费成人在线视频观看| 国产ts人妖一区二区| 91欧美一区二区| 欧美理论在线播放| 欧美国产精品专区| 亚洲一区二区黄色| 久久国产乱子精品免费女| 国产成人精品三级| 91官网在线免费观看| 日韩精品在线一区| 亚洲老司机在线| 久久99精品久久只有精品| 成人午夜电影久久影院| 欧美三级在线播放| 国产欧美日韩视频在线观看| 一二三区精品视频| 国产在线精品一区在线观看麻豆| 成人app软件下载大全免费| 欧美日韩国产影片| 久久精品人人做| 亚洲6080在线| 91视视频在线直接观看在线看网页在线看| 91成人看片片| 国产精品污www在线观看| 图片区小说区区亚洲影院| 国产成+人+日韩+欧美+亚洲| 91麻豆精品国产自产在线 | 视频一区免费在线观看| 国产传媒久久文化传媒| 欧美少妇bbb| 国产精品久久99| 九一久久久久久| 欧美精品自拍偷拍| 亚洲精品写真福利| 成人免费视频免费观看| 久久综合999| 三级影片在线观看欧美日韩一区二区| 国产成人在线视频网址| 日韩欧美激情四射| 五月天激情综合网| 在线国产电影不卡| 亚洲精品欧美专区| www.欧美日韩国产在线| 欧美激情综合在线| 国产宾馆实践打屁股91| 国产亚洲精品福利| 激情五月婷婷综合网| 欧美va亚洲va国产综合| 捆绑调教美女网站视频一区| 欧美一三区三区四区免费在线看| 亚洲高清视频在线| 欧美日韩一级片在线观看| 亚洲精品久久7777| 欧美熟乱第一页| 亚洲成人精品影院| 6080亚洲精品一区二区| 日日骚欧美日韩| 日韩精品中文字幕在线不卡尤物| 日日嗨av一区二区三区四区| 欧美一区二区三区免费在线看| 日韩主播视频在线| 欧美变态tickle挠乳网站| 精品亚洲国产成人av制服丝袜| 欧美不卡在线视频| 国产精品系列在线播放| 中文在线免费一区三区高中清不卡| 国产电影一区二区三区| 18成人在线视频| 欧美天天综合网| 日本三级亚洲精品| 久久精品亚洲麻豆av一区二区 | 91香蕉视频在线| 亚洲另类在线视频| 欧美日韩国产精选| 国内精品国产三级国产a久久| 国产视频亚洲色图| 在线视频一区二区三区| 午夜精品成人在线视频| 精品国产免费一区二区三区四区 | 亚洲素人一区二区| 欧美电影影音先锋| 国产精品性做久久久久久| 亚洲另类色综合网站| 欧美一区日韩一区| 99精品黄色片免费大全| 日韩高清欧美激情| 国产精品私人自拍| 欧美群妇大交群中文字幕| 国产资源精品在线观看| 亚洲一区二区三区四区中文字幕| 日韩欧美一区二区视频| 97精品电影院| 另类小说一区二区三区| 一区二区三区色| 欧美精品一区二区蜜臀亚洲| 色哟哟欧美精品| 国产精品99久久久久久似苏梦涵 | 免播放器亚洲一区| 国产精品成人一区二区艾草| 欧美一级国产精品| 91偷拍与自偷拍精品| 精彩视频一区二区三区| 亚洲电影在线免费观看| 国产精品三级av在线播放| 日韩精品中文字幕一区 | 蜜臀久久99精品久久久久久9| 中文字幕巨乱亚洲| 日韩欧美在线影院| 欧美伊人久久大香线蕉综合69| 国产一区二区视频在线播放| 午夜不卡av免费| 夜夜揉揉日日人人青青一国产精品| 国产视频一区在线观看| 精品国产a毛片| 91麻豆精品国产91久久久资源速度 | 日韩一区二区三区精品视频| 91久久精品一区二区二区| 国产成人日日夜夜| 久久精品国产亚洲高清剧情介绍| 亚洲bt欧美bt精品| 亚洲成人精品在线观看| 亚洲精品免费播放| 亚洲人成电影网站色mp4| 欧美激情一区二区| 国产日韩欧美一区二区三区综合| 精品少妇一区二区三区免费观看 | 日韩一区欧美二区| 亚洲第一在线综合网站| 午夜成人免费电影| 欧美aaa在线| 免费成人深夜小野草| 精品一区二区三区在线播放视频| 三级在线观看一区二区 | 国产欧美视频一区二区三区| 久久久久久久久久电影| 国产清纯白嫩初高生在线观看91 | 亚洲人123区| 亚洲免费观看高清完整 | 6080yy午夜一二三区久久| 欧美日韩国产色站一区二区三区| 欧美图区在线视频| 日韩欧美国产一区二区三区| 久久综合久久综合久久综合| 久久综合色天天久久综合图片| 精品国产乱码久久久久久久久 | 色哟哟在线观看一区二区三区| 成人激情免费视频| 91麻豆蜜桃一区二区三区| 日本丶国产丶欧美色综合| 欧美精品九九99久久| 精品盗摄一区二区三区| 国产欧美日韩综合精品一区二区| 1024国产精品| 天堂久久久久va久久久久| 狠狠色狠狠色综合| 成人激情电影免费在线观看| 色嗨嗨av一区二区三区| 欧美另类变人与禽xxxxx| 久久一区二区三区四区| 一区二区三区日韩在线观看| 日本美女一区二区| 成人的网站免费观看| 欧美曰成人黄网| 国产亚洲精品aa| 亚洲一二三四区不卡| 久久成人麻豆午夜电影| 色伊人久久综合中文字幕| 这里只有精品电影| 国产精品看片你懂得| 亚洲国产裸拍裸体视频在线观看乱了 | 国产精品看片你懂得| 日韩精品国产精品| 成人污视频在线观看| 欧美一卡二卡三卡四卡| 亚洲欧美色图小说| 国产精品一区二区男女羞羞无遮挡 | 国产精品拍天天在线| 青青国产91久久久久久|