码库记事本

码库记事本

SQL GROUP BY 详解及简单实例

小诸哥 0

 GROUP BY 语句用于结合 Aggregate 函数,根据一个或多个列对结果集进行分组。

SQL GROUP BY 语法

  1. SELECT column_name, aggregate_function(column_name)
  2. FROM table_name
  3. WHERE column_name operator value
  4. GROUP BY column_name;

 演示数据库

在本教程中,我们将使用众所周知的 Northwind 样本数据库。

下面是选自 "Orders" 表的数据:

OrderIDCustomerIDEmployeeIDOrderDateShipperID
102489051996-07-043
102498161996-07-051
102503441996-07-082

选自 "Shippers" 表的数据:

ShipperIDShipperNamePhone
1Speedy Express(503) 555-9831
2United Package(503) 555-3199
3Federal Shipping(503) 555-9931

选自 "Employees" 表的数据:

EmployeeIDLastNameFirstNameBirthDatePhotoNotes
1DavolioNancy1968-12-08EmpID1.picEducation includes a BA....
2FullerAndrew1952-02-19EmpID2.picAndrew received his BTS....
3LeverlingJanet1963-08-30EmpID3.picJanet has a BS degree....

 SQL GROUP BY 实例

现在我们想要查找每个送货员配送的订单数目。

下面的 SQL 语句按送货员进行订单分类统计:

  1. SELECT Shippers.ShipperName,COUNT(Orders.OrderID) ANumberOfOrders FROM Orders
  2. LEFT JOIN Shippers
  3. ON Orders.ShipperID=Shippers.ShipperID
  4. GROUP BY ShipperName;

GROUP BY 一个以上的列

我们也可以对一个以上的列应用 GROUP BY 语句,如下所示:

  1. SELECT Shippers.ShipperName, Employees.LastName,
  2. COUNT(Orders.OrderID) AS NumberOfOrders
  3. FROM ((Orders
  4. INNER JOIN Shippers
  5. ON Orders.ShipperID=Shippers.ShipperID)
  6. INNER JOIN Employees
  7. ON Orders.EmployeeID=Employees.EmployeeID)
  8. GROUP BY ShipperName,LastName;

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

标签: 详解 简单 实例

上一篇

下一篇精妙的SQL语句