⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 table.pas

📁 Crlab公司用来连接MySQL数据库的控件
💻 PAS
字号:
unit Table;

interface

uses
  Classes, SysUtils, DB,
{$IFNDEF LINUX}
  Windows, Messages, Graphics, Controls, Forms, Dialogs,
  DBCtrls, ExtCtrls, Grids, DBGrids, StdCtrls, ToolWin, ComCtrls, MyDacVcl,
  Buttons,
{$ELSE}
  Types, QGraphics, QControls, QForms, QDialogs, QStdCtrls,
  QDBCtrls, QComCtrls, QExtCtrls, QGrids, QDBGrids, MyDacClx, QButtons,
{$ENDIF}
  DBAccess, MyAccess, MemDS, DemoFrame;

type
  TTableFrame = class(TDemoFrame)
    DBGrid: TDBGrid;
    DataSource: TDataSource;
    Panel1: TPanel;
    MyTable: TMyTable;
    Panel2: TPanel;
    Panel3: TPanel;
    Panel4: TPanel;
    Label1: TLabel;
    edOrderFields: TComboBox;
    Label3: TLabel;
    btOpen: TSpeedButton;
    btClose: TSpeedButton;
    DBNavigator: TDBNavigator;
    edTableName: TComboBox;
    Panel8: TPanel;
    Panel9: TPanel;
    Label4: TLabel;
    edFilterSQL: TEdit;
    btExecute: TSpeedButton;
    btUnPrepare: TSpeedButton;
    btPrepare: TSpeedButton;
    procedure btOpenClick(Sender: TObject);
    procedure btCloseClick(Sender: TObject);
    procedure edTableNameExit(Sender: TObject);
    procedure edOrderFieldsExit(Sender: TObject);
    procedure edTableNameDropDown(Sender: TObject);
    procedure edOrderFieldsDropDown(Sender: TObject);
    procedure btPrepareClick(Sender: TObject);
    procedure btUnPrepareClick(Sender: TObject);
    procedure btExecuteClick(Sender: TObject);
  private
    { Private declarations }
    procedure ShowState;
    procedure SetTableProperties;
    procedure FillFieldList;
  public
    // Demo management
    procedure Initialize; override;
    procedure SetDebug(Value: boolean); override;
  end;

implementation

uses MyDacDemoForm;

{$IFDEF CLR}
{$R *.nfm}
{$ENDIF}
{$IFDEF WIN32}
{$R *.dfm}
{$ENDIF}
{$IFDEF LINUX}
{$R *.xfm}
{$ENDIF}

procedure TTableFrame.ShowState;
var
  St:string;

  procedure AddSt(S:string);
  begin
    if St <> '' then
      St:= St + ', ';
    St:= St + S;
  end;

begin
  St:= '';

  if MyTable.Prepared then begin
    AddSt('Prepared');

    if MyTable.IsQuery then
      AddSt('IsQuery');
  end;

  if MyTable.Active then
    AddSt('Active')
  else
    AddSt('Inactive');

  MyDACForm.StatusBar.Panels[1].Text:= St;
end;

procedure TTableFrame.SetTableProperties;
begin
  MyTable.TableName := edTableName.Text;
  MyTable.FilterSQL := edFilterSQL.Text;
  MyTable.OrderFields := edOrderFields.Text;
end;

procedure TTableFrame.btOpenClick(Sender: TObject);
begin
  SetTableProperties;
  ShowState;
  FillFieldList;
  try
    MyTable.OrderFields:= edOrderFields.Text;
    MyTable.Open;
  finally
    ShowState;
  end;
end;

procedure TTableFrame.btCloseClick(Sender: TObject);
begin
  MyTable.Close;
  ShowState;
end;

procedure TTableFrame.edTableNameExit(Sender: TObject);
begin
  if MyTable.TableName <> edTableName.Text then begin
    MyTable.TableName:= edTableName.Text;
    ShowState;
    FillFieldList;
  end;
end;

procedure TTableFrame.edOrderFieldsExit(Sender: TObject);
begin
  MyTable.OrderFields:= edOrderFields.Text;
  ShowState;
end;

procedure TTableFrame.edTableNameDropDown(Sender: TObject);
begin
  inherited;
  MyTable.Connection.GetTableNames(edTableName.Items);
end;

procedure TTableFrame.FillFieldList;
var
  i: integer;
  OrderFieldsTmp: string;
begin
  OrderFieldsTmp := MyTable.OrderFields;
  MyTable.OrderFields := '';
  MyTable.FieldDefs.Update;
  MyTable.OrderFields := OrderFieldsTmp;
  edOrderFields.Items.Clear;
  for i := 0 to MyTable.FieldDefs.Count - 1 do
    edOrderFields.Items.Add(MyTable.FieldDefs[i].Name);
end;

procedure TTableFrame.edOrderFieldsDropDown(Sender: TObject);
var
  oldDebug: boolean;
begin
  inherited;
  oldDebug := MyTable.Debug;
  MyTable.Debug := false;
  try
    FillFieldList;
  finally
    MyTable.Debug := oldDebug;
  end;
end;

procedure TTableFrame.btPrepareClick(Sender: TObject);
begin
  try
    SetTableProperties;
    MyTable.Prepare;
  finally
    ShowState;
  end;
end;

procedure TTableFrame.btUnPrepareClick(Sender: TObject);
begin
  MyTable.UnPrepare;
  ShowState;
end;

procedure TTableFrame.btExecuteClick(Sender: TObject);
begin
  try
    SetTableProperties;
    MyTable.Execute;
  finally
    ShowState;
  end;
end;

// Demo management
procedure TTableFrame.Initialize;
begin
  edTableName.Text:= MyTable.TableName;
  edOrderFields.Text:= MyTable.OrderFields;
  ShowState;
end;

procedure TTableFrame.SetDebug(Value: boolean);
begin
  MyTable.Debug := Value;
end;

end.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -