Something like this can work without tremendous effort:
SELECT c.name AS 'ColumnName'
,t.name AS 'TableName'
,p.rows
FROM sys.columns c
INNER JOIN sys.tables t
ON c.object_id = t.object_id
INNER JOIN sys.partitions p
on t.object_id = p.object_id
WHERE c.name LIKE '%p%'
AND p.rows > 0
ORDER BY TableName
,ColumnName;
, sys.partitions ; sys.dm_db_index_physical_stats (. https://dba.stackexchange.com/questions/55124/how-accurate-is-the-sys-partition-rows-column). , , AlwaysOn:
SELECT c.name AS 'ColumnName'
,t.name AS 'TableName'
,ips.record_count
FROM sys.columns c
INNER JOIN sys.tables t
ON c.object_id = t.object_id
CROSS APPLY sys.dm_db_index_physical_stats(DB_ID(), t.object_id, null, null, 'DETAILED') ips
WHERE c.name LIKE '%p%'
AND ips.record_count > 0
ORDER BY TableName
,ColumnName;
100% - , COUNT(*) ( Dynamic SQL), , , , .