• 学习 SQL 语句 Select(3): 条件查询与模糊查询



    Where 用来指定查询条件;

    Like 和 Not Like 来指定模糊条件;

    模糊条件中:
    _ 表示任一字符;
    % 表示任一字符串;
    [] 表示一个集合.

    本例效果图:



    代码文件:
    unit Unit1;
    
    interface
    
    uses
      Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
      Dialogs, StdCtrls, ExtCtrls, Grids, DBGrids, DB, ADODB;
    
    type
      TForm1 = class(TForm)
        DBGrid1: TDBGrid;
        DataSource1: TDataSource;
        ADODataSet1: TADODataSet;
        Panel1: TPanel;
        Button1: TButton;
        Button2: TButton;
        Button3: TButton;
        Button4: TButton;
        Button5: TButton;
        Button6: TButton;
        Button7: TButton;
        Button8: TButton;
        Button9: TButton;
        Button10: TButton;
        Button11: TButton;
        Button12: TButton;
        Button13: TButton;
        Button14: TButton;
        procedure FormCreate(Sender: TObject);
        procedure Button1Click(Sender: TObject);
        procedure Button2Click(Sender: TObject);
        procedure Button3Click(Sender: TObject);
        procedure Button4Click(Sender: TObject);
        procedure Button5Click(Sender: TObject);
        procedure Button6Click(Sender: TObject);
        procedure Button7Click(Sender: TObject);
        procedure Button8Click(Sender: TObject);
        procedure Button9Click(Sender: TObject);
        procedure Button10Click(Sender: TObject);
        procedure Button11Click(Sender: TObject);
        procedure Button12Click(Sender: TObject);
        procedure Button13Click(Sender: TObject);
        procedure Button14Click(Sender: TObject);
      end;
    
    var
      Form1: TForm1;
    
    implementation
    
    {$R *.dfm}
    
    //country 表中 Area<200000 的记录
    procedure TForm1.Button1Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Area<200000';
        Open;
      end;
    end;
    
    //country 表中 Continent="South America" 的记录; 字符串值应该在引号中(单引号、双引号均可).
    procedure TForm1.Button2Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Continent="South America"';
        Open;
      end;
    end;
    
    //country 表中 Name="Cuba" 或者 Name="Peru" 的记录
    procedure TForm1.Button3Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name="Cuba" or Name="Peru"';
        Open;
      end;
    end;
    
    //country 表中 Continent="South America" 并且 Area>1000000 的记录
    procedure TForm1.Button4Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Continent="South America" and Area>1000000';
        Open;
      end;
    end;
    
    //country 表中 Name 是 c 开头的记录; 其中的 % 表示任意字符串
    procedure TForm1.Button5Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name LIKE "c%"';
        Open;
      end;
    end;
    
    //country 表中 Name 是 b 或 c 开头的记录; 可以用 "," 隔开更多条件
    procedure TForm1.Button6Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name LIKE "[b,c]%"';
        Open;
      end;
    end;
    
    //country 表中 Name 是 a 或 b 或 c 开头的记录
    procedure TForm1.Button7Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name LIKE "[a-c]%"';
        Open;
      end;
    end;
    
    //country 表中 Name 不是 a 或 b 或 c 或 m 开头的记录
    procedure TForm1.Button8Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name NOT LIKE "[a-c,m]%"';
        Open;
      end;
    end;
    
    //country 表中 Name 不是 a 或 b 或 c 开头的记录
    procedure TForm1.Button9Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name NOT LIKE "[a-c]%"';
        Open;
      end;
    end;
    
    //country 表中 Name 包含 er 的记录
    procedure TForm1.Button10Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name LIKE "%er%"';
        Open;
      end;
    end;
    
    //country 表中 Name 包含空格的记录
    procedure TForm1.Button11Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name LIKE "% %"';
        Open;
      end;
    end;
    
    //country 表中 Name 第二个字符任意, 但第一字符是 p、第三字符是 r 的记录; "_" 表示任意字符
    procedure TForm1.Button12Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name LIKE "p_r%"';
        Open;
      end;
    end;
    
    //country 表中 Name 是 4 个字符的记录
    procedure TForm1.Button13Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name LIKE "____"';
        Open;
      end;
    end;
    
    //country 表中 Name 是 4 个字符, 但最后是 a 结尾的记录
    procedure TForm1.Button14Click(Sender: TObject);
    begin
      with ADODataSet1 do begin
        Close;
        CommandText := 'SELECT * FROM country WHERE Name LIKE "___a"';
        Open;
      end;
    end;
    
    procedure TForm1.FormCreate(Sender: TObject);
    var
      mdbFile: string;
    begin
      mdbFile := GetEnvironmentVariable('COMMONPROGRAMFILES');
      mdbFile := mdbFile + '\CodeGear Shared\Data\dbdemos.mdb';
    
      ADODataSet1.ConnectionString := 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=' +
        mdbFile + ';Persist Security Info=False';
    
      DBGrid1.DataSource := DataSource1;
      DataSource1.DataSet := ADODataSet1;
    end;
    
    end.
    

    窗体文件:
    object Form1: TForm1
      Left = 0
      Top = 0
      Caption = 'Form1'
      ClientHeight = 407
      ClientWidth = 626
      Color = clBtnFace
      Font.Charset = DEFAULT_CHARSET
      Font.Color = clWindowText
      Font.Height = -11
      Font.Name = 'Tahoma'
      Font.Style = []
      OldCreateOrder = False
      OnCreate = FormCreate
      PixelsPerInch = 96
      TextHeight = 13
      object DBGrid1: TDBGrid
        Left = 0
        Top = 65
        Width = 626
        Height = 342
        Align = alClient
        DataSource = DataSource1
        TabOrder = 0
        TitleFont.Charset = DEFAULT_CHARSET
        TitleFont.Color = clWindowText
        TitleFont.Height = -11
        TitleFont.Name = 'Tahoma'
        TitleFont.Style = []
      end
      object Panel1: TPanel
        Left = 0
        Top = 0
        Width = 626
        Height = 65
        Align = alTop
        Caption = 'Panel1'
        TabOrder = 1
        object Button1: TButton
          Left = 6
          Top = 5
          Width = 75
          Height = 25
          Caption = 'Button1'
          TabOrder = 0
          OnClick = Button1Click
        end
        object Button2: TButton
          Left = 87
          Top = 5
          Width = 75
          Height = 25
          Caption = 'Button2'
          TabOrder = 1
          OnClick = Button2Click
        end
        object Button3: TButton
          Left = 168
          Top = 5
          Width = 75
          Height = 25
          Caption = 'Button3'
          TabOrder = 2
          OnClick = Button3Click
        end
        object Button4: TButton
          Left = 249
          Top = 5
          Width = 75
          Height = 25
          Caption = 'Button4'
          TabOrder = 3
          OnClick = Button4Click
        end
        object Button5: TButton
          Left = 330
          Top = 5
          Width = 75
          Height = 25
          Caption = 'Button5'
          TabOrder = 4
          OnClick = Button5Click
        end
        object Button6: TButton
          Left = 411
          Top = 5
          Width = 75
          Height = 25
          Caption = 'Button6'
          TabOrder = 5
          OnClick = Button6Click
        end
        object Button7: TButton
          Left = 492
          Top = 5
          Width = 75
          Height = 25
          Caption = 'Button7'
          TabOrder = 6
          OnClick = Button7Click
        end
        object Button8: TButton
          Left = 6
          Top = 36
          Width = 75
          Height = 25
          Caption = 'Button8'
          TabOrder = 7
          OnClick = Button8Click
        end
        object Button9: TButton
          Left = 87
          Top = 36
          Width = 75
          Height = 25
          Caption = 'Button9'
          TabOrder = 8
          OnClick = Button9Click
        end
        object Button10: TButton
          Left = 168
          Top = 36
          Width = 75
          Height = 25
          Caption = 'Button10'
          TabOrder = 9
          OnClick = Button10Click
        end
        object Button11: TButton
          Left = 249
          Top = 36
          Width = 75
          Height = 25
          Caption = 'Button11'
          TabOrder = 10
          OnClick = Button11Click
        end
        object Button12: TButton
          Left = 330
          Top = 34
          Width = 75
          Height = 25
          Caption = 'Button12'
          TabOrder = 11
          OnClick = Button12Click
        end
        object Button13: TButton
          Left = 411
          Top = 36
          Width = 75
          Height = 25
          Caption = 'Button13'
          TabOrder = 12
          OnClick = Button13Click
        end
        object Button14: TButton
          Left = 492
          Top = 36
          Width = 75
          Height = 25
          Caption = 'Button14'
          TabOrder = 13
          OnClick = Button14Click
        end
      end
      object DataSource1: TDataSource
        DataSet = ADODataSet1
        Left = 184
        Top = 112
      end
      object ADODataSet1: TADODataSet
        CursorType = ctStatic
        Parameters = <>
        Left = 232
        Top = 184
      end
    end
    
  • 相关阅读:
    只出现一次的数字
    SpringBoot整合Redis
    MFC 0误差画图
    模仿.NET的序列化机制
    求最大子数组
    让CFrameWnd派生类的对象响应鼠标消息的“变态”方法
    关于chm文件和'#'的惊人发现
    CxImage学习笔记
    C++指针系列
    MFC,C++ 截屏
  • 原文地址:https://www.cnblogs.com/del/p/1491287.html
Copyright © 2020-2023  润新知