SQL COUNT() 函数

COUNT() 函数返回匹配指定条件的行数。


SQL COUNT() 语法

SQL COUNT(column_name) 语法

COUNT(column_name) 函数返回指定列的值的数目(NULL 不计入):

  1. SELECT COUNT(column_name) FROM table_name
SQL COUNT(*) 语法

COUNT(*) 函数返回表中的记录数:

  1. SELECT COUNT(*) FROM table_name
SQL COUNT(DISTINCT column_name) 语法

COUNT(DISTINCT column_name) 函数返回指定列的不同值的数目:

  1. SELECT COUNT(DISTINCT column_name) FROM table_name

注释:COUNT(DISTINCT) 适用于 ORACLE 和 Microsoft SQL Server,但是无法用于 Microsoft Access。


SQL COUNT(column_name) 实例

我们拥有下列 "Orders" 表:

O_IdOrderDateOrderPriceCustomer
12021/12/291000Bush
22021/11/231600Carter
32021/10/05700Bush
42021/09/28300Bush
52021/08/062000Adams
62021/07/21100Carter

现在,我们希望计算客户 "Carter" 的订单数。

我们使用如下 SQL 语句:

  1. SELECT COUNT(Customer) AS CustomerNilsen FROM Orders
  2. WHERE Customer='Carter'

以上 SQL 语句的结果是 2,因为客户 Carter 共有 2 个订单:

CustomerNilsen
2

SQL COUNT() 实例如果我们省略 WHERE 子句,比如这样:SELECT COUNT() AS NumberOfOrders FROM Orders结果集类似这样:NumberOfOrders6这是表中的总行数。


SQL COUNT(DISTINCT column_name) 实例

现在,我们希望计算 "Orders" 表中不同客户的数目。

我们使用如下 SQL 语句:

  1. SELECT COUNT(*) AS NumberOfOrders FROM Orders

结果集类似这样:

NumberOfCustomers
3

这是 "Orders" 表中不同客户(Bush, Carter 和 Adams)的数目。

分类导航