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

📄 bjxxcx.pas

📁 本系统是基于企业局域网平台针对企业安防
💻 PAS
字号:
unit bjxxcx;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, ExtCtrls, StdCtrls, ComCtrls, Buttons, Grids, DBGrids, DB;

type
  TForm23 = class(TForm)
    Panel1: TPanel;
    CheckBox1: TCheckBox;
    Label1: TLabel;
    ComboBox1: TComboBox;
    ComboBox2: TComboBox;
    CheckBox2: TCheckBox;
    Label2: TLabel;
    DateTimePicker1: TDateTimePicker;
    SpeedButton1: TSpeedButton;
    DataSource1: TDataSource;
    DBGrid1: TDBGrid;
    Panel2: TPanel;
    CheckBox3: TCheckBox;
    CheckBox4: TCheckBox;
    DateTimePicker2: TDateTimePicker;
    Label3: TLabel;
    procedure ComboBox1Change(Sender: TObject);
    procedure SpeedButton1Click(Sender: TObject);
    procedure FormShow(Sender: TObject);
    procedure CheckBox3Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form23: TForm23;

implementation
  uses DataModal;
{$R *.dfm}

procedure TForm23.ComboBox1Change(Sender: TObject);
begin
  ComboBox2.Clear;
  with Data.ADOQuery1 do
  begin
    Close;
    SQL.Clear;
    SQL.Add('Select distinct '+ Trim(ComboBox1.Text)+ ' From 日志记录表');
    Open;    
    if Data.ADOQuery1.RecordCount>0 then
    begin
      while Not Eof do
      begin
        ComboBox2.Items.Add(Fields[0].Value);
        Next;
      end;
      ComboBox2.ItemIndex := 0;
    end;
  end;
end;

procedure TForm23.SpeedButton1Click(Sender: TObject);
begin
  CheckBox3.Checked := False;
  if (Not CheckBox1.Checked)and(Not CheckBox2.Checked)and(Not CheckBox4.Checked)then
  begin
    with Data.ADOQuery2 do
    begin
      Close;
      SQL.Clear;
      SQL.Add('select 楼层名称 ,楼层,项目名称,设备数据 from 日志记录表 a inner join 楼层信息表 b on a.楼层编号 = b.楼层编号 and a.误报 = 0');
      Open;
    end;
    if Data.ADOQuery2.RecordCount>0 then
      DataSource1.DataSet := Data.ADOQuery2
    else
    begin
      DataSource1.DataSet := Nil;
      Application.MessageBox('没有符合条件的记录.','提示',64);
    end;
  end
  else if(CheckBox1.Checked)and(Not CheckBox2.Checked)then
  begin
    with Data.ADOQuery2 do
    begin
      Close;
      SQL.Clear;
      if Trim(ComboBox2.Text)<>'' then
      begin
        if Not CheckBox4.Checked then
        begin
          SQL.Add('select 楼层名称 ,楼层,项目名称,设备数据 from 日志记录表 a inner join 楼层信息表 b on a.楼层编号 = b.楼层编号 and a.'+ComboBox1.Text + ' =:a and 误报 = 0');
          Parameters.ParamByName('a').Value := Trim(ComboBox2.Text);
          Open;
        end
        else
        begin
          SQL.Add('select 楼层名称 ,楼层,项目名称,设备数据 from 日志记录表 a inner join 楼层信息表 b on a.楼层编号 = b.楼层编号 and a.'+ComboBox1.Text + ' =:a and 误报 = 1');
          Parameters.ParamByName('a').Value := Trim(ComboBox2.Text);
          Open;
        end;
        if RecordCount>0 then
          DataSource1.DataSet := Data.ADOQuery2
        else
        begin
          DataSource1.DataSet := Nil;
          Application.MessageBox('没有符合条件的记录.','提示',64);
        end;
      end;
    end;
  end
  else if(Not CheckBox1.Checked)and(CheckBox2.Checked)then
  begin
    with Data.ADOQuery2 do
    begin
      Close;
      SQL.Clear;
      if Not CheckBox4.Checked then
      begin
        SQL.Add('select 楼层名称 ,楼层,项目名称,设备数据 from 日志记录表 a inner join 楼层信息表 b on a.楼层编号 = b.楼层编号 and a.时间 >= :a and a.时间<= :b and 误报 = 0');
        Parameters.ParamByName('a').Value := Trunc(DateTimePicker1.DateTime-2);
        Parameters.ParamByName('b').Value := Trunc(DateTimePicker2.DateTime-2)+1;
        Open;
      end
      else
      begin
        SQL.Add('select 楼层名称 ,楼层,项目名称,设备数据 from 日志记录表 a inner join 楼层信息表 b on a.楼层编号 = b.楼层编号 and a.时间 >= :a and a.时间<= :b and 误报 = 1');
        Parameters.ParamByName('a').Value := Trunc(DateTimePicker1.DateTime-2);
        Parameters.ParamByName('b').Value := Trunc(DateTimePicker2.DateTime-2)+1;
        Open;
      end;
      if RecordCount>0 then
        DataSource1.DataSet := Data.ADOQuery2
      else
      begin
        DataSource1.DataSet := Nil;
        Application.MessageBox('没有符合条件的记录.','提示',64);
      end;
    end;
  end
  else if CheckBox4.Checked then
  begin
    with Data.ADOQuery2 do
    begin
      Close;
      SQL.Clear;
      SQL.Add('select 楼层名称 ,楼层,项目名称,设备数据 from 日志记录表 a inner join 楼层信息表 b on a.楼层编号 = b.楼层编号 and a.误报 = 1');
      Open;
    end;
    if Data.ADOQuery2.RecordCount>0 then
      DataSource1.DataSet := Data.ADOQuery2
    else
    begin
      DataSource1.DataSet := Nil;
      Application.MessageBox('没有符合条件的记录.','提示',64);
    end;
  end;   
end;

procedure TForm23.FormShow(Sender: TObject);
begin
  DateTimePicker1.DateTime := Now;
  DateTimePicker2.DateTime := Now;
end;

procedure TForm23.CheckBox3Click(Sender: TObject);
begin
  if CheckBox3.Checked then
  begin
    with Data.ADOQuery2 do
    begin
      Close;
      SQL.Clear;
      SQL.Add('select 楼层名称 ,楼层,项目名称,设备数据 from 日志记录表 a inner join 楼层信息表 b on a.楼层编号 = b.楼层编号 ');
      Open;
    end;
    if Data.ADOQuery2.RecordCount>0 then
      DataSource1.DataSet := Data.ADOQuery2
    else
    begin
      DataSource1.DataSet := Nil;
      Application.MessageBox('没有符合条件的记录.','提示',64);
    end;
  end;
end;

end.

⌨️ 快捷键说明

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