在 SQL 中,SELECT COUNT(*)
和 SELECT COUNT(1)
都用于统计符合条件的行数,但它们在具体实现和效率上有一些区别。
-
SELECT COUNT(*)
:这是一种常见且通用的写法,它会统计所有符合查询条件的行数,包括所有列,不包括 NULL 值。它会对查询的每一行进行计数,这可能涉及扫描整个表或使用索引。 -
SELECT COUNT(1)
:这是一种更为简洁和高效的写法。它会统计符合查询条件的行数,但实际上并不关心查询的具体列。因为我们只关心存在与否,所以使用任意常量(例如 1)代替列名即可。
在实际运行中,SELECT COUNT(1)
往往比 SELECT COUNT(*)
更高效。这是因为数据库引擎在执行查询时,并不需要获取所有列的数据,只需要判断是否存在即可。使用 SELECT COUNT(1)
可以避免读取额外的数据,从而提高查询性能。
SELECT COUNT(*) 写法
可以根据某个字段非空查询
例:SELECT COUNT(column_name) FROM TABLE
当然还可以这样写
SELECT COUNT(CASE WHEN Column1 IS NOT NULL OR Column2 IS NOT NULL THEN 1 END) AS NonNullCount
FROM YourTable;