Group By
本来 Group By 也可以根据多个字段分组("," 隔开), 但这个例子只有 Continent 字段适合分组,
也只有 Area、Population 字段适合统计.
本例效果图:
代码文件:
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; procedure FormCreate(Sender: TObject); procedure Button1Click(Sender: TObject); procedure Button2Click(Sender: TObject); procedure Button3Click(Sender: TObject); procedure Button4Click(Sender: TObject); procedure Button5Click(Sender: TObject); end; var Form1: TForm1; implementation {$R *.dfm} procedure TForm1.Button1Click(Sender: TObject); begin with ADODataSet1 do begin Close; CommandText := 'SELECT Continent, ' + 'AVG(Area) AS 平均面积, AVG(Population) AS 平均人口 ' + 'FROM country GROUP BY Continent'; Open; end; end; procedure TForm1.Button2Click(Sender: TObject); begin with ADODataSet1 do begin Close; CommandText := 'SELECT Continent, ' + 'SUM(Area) AS 面积总数, SUM(Population) AS 人口总数 ' + 'FROM country GROUP BY Continent'; Open; end; end; procedure TForm1.Button3Click(Sender: TObject); begin with ADODataSet1 do begin Close; CommandText := 'SELECT Continent, ' + 'MAX(Area) AS 面积最大, MIN(Population) AS 人口最少 ' + 'FROM country GROUP BY Continent'; Open; end; end; procedure TForm1.Button4Click(Sender: TObject); begin with ADODataSet1 do begin Close; CommandText := 'SELECT Continent, ' + 'MAX(Area + Population) AS 面积与人口总和最多, ' + 'MIN(Area + Population) AS 面积与人口总和最少 ' + 'FROM country GROUP BY Continent'; Open; end; end; procedure TForm1.Button5Click(Sender: TObject); begin with ADODataSet1 do begin Close; CommandText := 'SELECT COUNT(*) AS 记录总数 FROM country'; 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 = 33 Width = 626 Height = 374 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 = 33 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 end object DataSource1: TDataSource DataSet = ADODataSet1 Left = 184 Top = 112 end object ADODataSet1: TADODataSet CursorType = ctStatic Parameters = <> Left = 232 Top = 184 end end