SQL COUNT() 函數(shù)
COUNT() 函數(shù)返回匹配指定條件的行數(shù)。
SQL COUNT() 語法
SQL COUNT(column_name) 語法
COUNT(column_name) 函數(shù)返回指定列的值的數(shù)目(NULL 不計(jì)入):
SELECT COUNT(column_name) FROM table_name
SQL COUNT(*) 語法
COUNT(*) 函數(shù)返回表中的記錄數(shù):
SELECT COUNT(*) FROM table_name
SQL COUNT(DISTINCT column_name) 語法
COUNT(DISTINCT column_name) 函數(shù)返回指定列的不同值的數(shù)目:
SELECT COUNT(DISTINCT column_name) FROM table_name
注釋:COUNT(DISTINCT) 適用于 ORACLE 和 Microsoft SQL Server,但是無法用于 Microsoft Access。
SQL COUNT(column_name) 實(shí)例
我們擁有下列 "Orders" 表:
O_Id | OrderDate | OrderPrice | Customer |
---|---|---|---|
1 | 2008/12/29 | 1000 | Bush |
2 | 2008/11/23 | 1600 | Carter |
3 | 2008/10/05 | 700 | Bush |
4 | 2008/09/28 | 300 | Bush |
5 | 2008/08/06 | 2000 | Adams |
6 | 2008/07/21 | 100 | Carter |
現(xiàn)在,我們希望計(jì)算客戶 "Carter" 的訂單數(shù)。
我們使用如下 SQL 語句:
SELECT COUNT(Customer) AS CustomerNilsen FROM Orders WHERE Customer='Carter'
以上 SQL 語句的結(jié)果是 2,因?yàn)榭蛻?Carter 共有 2 個(gè)訂單:
CustomerNilsen |
---|
2 |
SQL COUNT(*) 實(shí)例
如果我們省略 WHERE 子句,比如這樣:
SELECT COUNT(*) AS NumberOfOrders FROM Orders
結(jié)果集類似這樣:
NumberOfOrders |
---|
6 |
這是表中的總行數(shù)。
SQL COUNT(DISTINCT column_name) 實(shí)例
現(xiàn)在,我們希望計(jì)算 "Orders" 表中不同客戶的數(shù)目。
我們使用如下 SQL 語句:
SELECT COUNT(DISTINCT Customer) AS NumberOfCustomers FROM Orders
結(jié)果集類似這樣:
NumberOfCustomers |
---|
3 |
這是 "Orders" 表中不同客戶(Bush, Carter 和 Adams)的數(shù)目。