DECLARE @table NVARCHAR(512);
SET @table = N'dbo.tablename';
DECLARE @sql NVARCHAR(MAX);
SELECT @sql = N'';
SELECT @sql = @sql + QUOTENAME(name)
+ ' = SUM(CASE WHEN ' + QUOTENAME(name) + ' IS NULL THEN 1 ELSE 0 END),'
FROM sys.columns
WHERE object_id = OBJECT_ID(@table)
AND is_nullable = 1;
SELECT @sql = 'SELECT ' + @sql + ' Total_Count = COUNT(*)
FROM ' + @table + ';';
EXEC sp_executesql @sql;
Bất kỳ cột nào đi ra 0 đều có tất cả các giá trị null (trừ khi cột Total_Count cũng là 0, trong trường hợp đó bảng trống). Lưu ý rằng truy vấn này sẽ khá tốn kém trên một bảng lớn.