COUNT (SQL Bertransaksi)

Berlaku untuk:yes SQL Server (semua versi yang didukung) YesAzure SQL Database YesAzure SQL Managed Instance yesAzure Synapse Analytics Analytics yesPlatform System (PDW)

Fungsi ini mengembalikan jumlah item yang ditemukan dalam grup. COUNT beroperasi seperti fungsi COUNT_BIG . Fungsi-fungsi ini hanya berbeda dalam jenis data nilai yang dikembalikan. COUNT selalu mengembalikan nilai tipe data int . COUNT_BIG selalu mengembalikan nilai jenis data bigint .

Topic link iconKonvensi Sintaksis T-SQL

Sintaks


-- Aggregation Function Syntax  
COUNT ( { [ [ ALL | DISTINCT ] expression ] | * } )  

-- Analytic Function Syntax  
COUNT ( [ ALL ]  { expression | * } ) OVER ( [ <partition_by_clause> ] )  

Catatan

Untuk melihat sintaks transact-SQL untuk SQL Server 2014 dan yang lebih lama, lihat Dokumentasi versi sebelumnya.

Argumen

ALL
Menerapkan fungsi agregat ke semua nilai. ALL berfungsi sebagai default.

DISTINCT
Menentukan yang COUNT mengembalikan jumlah nilai nonnull unik.

ekspresi
Ekspresi jenis apa pun, kecuali gambar, ntext, atau teks. Perhatikan bahwa COUNT tidak mendukung fungsi agregat atau subkueri dalam ekspresi.

*
Menentukan bahwa COUNT harus menghitung semua baris untuk menentukan jumlah baris tabel total yang akan dikembalikan. COUNT(*) tidak mengambil parameter dan tidak mendukung penggunaan DISTINCT. COUNT(*) tidak memerlukan parameter ekspresi karena menurut definisi, parameter tersebut tidak menggunakan informasi tentang kolom tertentu. COUNT(*) mengembalikan jumlah baris dalam tabel tertentu, dan mempertahankan baris duplikat. Ini menghitung setiap baris secara terpisah. Ini termasuk baris yang berisi nilai null.

OVER ( [ partition_by_clause ] [ order_by_clause ] [ ROW_or_RANGE_clause ] )
partition_by_clause membagi tataan hasil yang dihasilkan oleh FROM klausul menjadi partisi tempat COUNT fungsi diterapkan. Jika tidak ditentukan, fungsi memperlakukan semua baris hasil kueri yang ditetapkan sebagai grup tunggal. order_by_clause menentukan urutan logis operasi. Lihat Klausa OVER (SQL T-SQL) untuk informasi selengkapnya.

Tipe yang dikembalikan

int

Keterangan

COUNT(*) mengembalikan jumlah item dalam grup. Ini termasuk nilai NULL dan duplikat.

COUNT(ALL expression) mengevaluasi ekspresi untuk setiap baris dalam grup, dan mengembalikan jumlah nilai nonnull.

COUNT( EKSPRESI DISTINCT) mengevaluasi ekspresi untuk setiap baris dalam grup, dan mengembalikan jumlah nilai nonnull yang unik.

Untuk nilai yang dikembalikan melebihi 2^31-1, COUNT mengembalikan kesalahan. Untuk kasus ini, gunakan COUNT_BIG sebagai gantinya.

COUNT adalah fungsi deterministik ketika digunakan tanpa klausa OVER dan ORDER BY. Ini nondeterministik ketika digunakan dengan klausul OVER dan ORDER BY. Lihat Fungsi Deterministik dan Nondeterministik untuk informasi selengkapnya.

Contoh

A. Menggunakan COUNT dan DISTINCT

Contoh ini mengembalikan jumlah judul berbeda yang dapat dipegang oleh karyawan Adventure Works Cycles.

SELECT COUNT(DISTINCT Title)  
FROM HumanResources.Employee;  
GO  

Berikut adalah tataan hasil.

-----------
67  
  
(1 row(s) affected)

B. Menggunakan COUNT(*)

Contoh ini mengembalikan jumlah total karyawan Adventure Works Cycles.

SELECT COUNT(*)  
FROM HumanResources.Employee;  
GO  

Berikut adalah hasil yang ditetapkan.

-----------
290  
  
(1 row(s) affected)

C. Menggunakan COUNT(*) dengan agregat lain

Contoh ini menunjukkan bahwa COUNT(*) berfungsi dengan fungsi agregat lainnya dalam SELECT daftar. Contohnya menggunakan database AdventureWorks2012.

SELECT COUNT(*), AVG(Bonus)  
FROM Sales.SalesPerson  
WHERE SalesQuota > 25000;  
GO  

Berikut adalah hasil yang ditetapkan.

----------- ---------------------
14            3472.1428
  
(1 row(s) affected)

D. Menggunakan klausa OVER

Contoh ini menggunakan MINfungsi , MAX, AVG dan COUNT dengan OVER klausul , untuk mengembalikan nilai agregat untuk setiap departemen dalam tabel database HumanResources.Department AdventureWorks2012.

SELECT DISTINCT Name  
       , MIN(Rate) OVER (PARTITION BY edh.DepartmentID) AS MinSalary  
       , MAX(Rate) OVER (PARTITION BY edh.DepartmentID) AS MaxSalary  
       , AVG(Rate) OVER (PARTITION BY edh.DepartmentID) AS AvgSalary  
       ,COUNT(edh.BusinessEntityID) OVER (PARTITION BY edh.DepartmentID) AS EmployeesPerDept  
FROM HumanResources.EmployeePayHistory AS eph  
JOIN HumanResources.EmployeeDepartmentHistory AS edh  
     ON eph.BusinessEntityID = edh.BusinessEntityID  
JOIN HumanResources.Department AS d  
ON d.DepartmentID = edh.DepartmentID
WHERE edh.EndDate IS NULL  
ORDER BY Name;  

Berikut adalah hasil yang ditetapkan.

Name                          MinSalary             MaxSalary             AvgSalary             EmployeesPerDept  
----------------------------- --------------------- --------------------- --------------------- ----------------  
Document Control              10.25                 17.7885               14.3884               5  
Engineering                   32.6923               63.4615               40.1442               6  
Executive                     39.06                 125.50                68.3034               4  
Facilities and Maintenance    9.25                  24.0385               13.0316               7  
Finance                       13.4615               43.2692               23.935                10  
Human Resources               13.9423               27.1394               18.0248               6  
Information Services          27.4038               50.4808               34.1586               10  
Marketing                     13.4615               37.50                 18.4318               11  
Production                    6.50                  84.1346               13.5537               195  
Production Control            8.62                  24.5192               16.7746               8  
Purchasing                    9.86                  30.00                 18.0202               14  
Quality Assurance             10.5769               28.8462               15.4647               6  
Research and Development      40.8654               50.4808               43.6731               4  
Sales                         23.0769               72.1154               29.9719               18  
Shipping and Receiving        9.00                  19.2308               10.8718               6  
Tool Design                   8.62                  29.8462               23.5054               6  
  
(16 row(s) affected)

Contoh: Azure Synapse Analytics and Analytics Platform System (PDW)

E. Menggunakan COUNT dan DISTINCT

Contoh ini mengembalikan jumlah judul berbeda yang dapat dipegang oleh karyawan perusahaan tertentu.

USE ssawPDW;  
  
SELECT COUNT(DISTINCT Title)  
FROM dbo.DimEmployee;  

Berikut adalah hasil yang ditetapkan.

-----------
67

F. Menggunakan COUNT(*)

Contoh ini mengembalikan jumlah total baris dalam dbo.DimEmployee tabel.

USE ssawPDW;  
  
SELECT COUNT(*)  
FROM dbo.DimEmployee;  

Berikut adalah hasil yang ditetapkan.

-------------
296

G. Menggunakan COUNT(*) dengan agregat lain

Contoh ini dikombinasikan COUNT(*) dengan fungsi agregat lainnya dalam SELECT daftar. Ini mengembalikan jumlah perwakilan penjualan dengan kuota penjualan tahunan yang lebih besar dari $500.000, dan kuota penjualan rata-rata perwakilan penjualan tersebut.

USE ssawPDW;  
  
SELECT COUNT(EmployeeKey) AS TotalCount, AVG(SalesAmountQuota) AS [Average Sales Quota]  
FROM dbo.FactSalesQuota  
WHERE SalesAmountQuota > 500000 AND CalendarYear = 2001;  
  

Berikut adalah hasil yang ditetapkan.

TotalCount  Average Sales Quota
----------  -------------------
10          683800.0000

H. Menggunakan COUNT dengan HAVING

Contoh ini menggunakan dengan HAVING klausul COUNT untuk mengembalikan departemen perusahaan, yang masing-masing memiliki lebih dari 15 karyawan.

USE ssawPDW;  
  
SELECT DepartmentName,   
       COUNT(EmployeeKey)AS EmployeesInDept  
FROM dbo.DimEmployee  
GROUP BY DepartmentName  
HAVING COUNT(EmployeeKey) > 15;  

Berikut adalah hasil yang ditetapkan.

DepartmentName  EmployeesInDept
--------------  ---------------
Sales           18
Production      179

i. Menggunakan COUNT dengan OVER

Contoh ini menggunakan dengan OVER klausul COUNT , untuk mengembalikan jumlah produk yang terkandung dalam setiap pesanan penjualan yang ditentukan.

USE ssawPDW;  
  
SELECT DISTINCT COUNT(ProductKey) OVER(PARTITION BY SalesOrderNumber) AS ProductCount  
    ,SalesOrderNumber  
FROM dbo.FactInternetSales  
WHERE SalesOrderNumber IN (N'SO53115',N'SO55981');  

Berikut adalah hasil yang ditetapkan.

ProductCount   SalesOrderID`
------------   -----------------
3              SO53115
1              SO55981

Lihat juga

Fungsi Agregat (T-SQL)
COUNT_BIG (SQL Bertransaksi)
Klausul OVER (SQL Bertransaksi)