Създайте от INFORMATION_SCHEMA.COLUMNS
таблица низ, който съдържа SQL, който искате да изпълните, след което подгответе изявление
от този низ и го изпълнете.
SQL, който искаме да изградим, ще изглежда така:
SELECT 'column_a'
FROM table_name
WHERE `column_a` IS NOT NULL
HAVING COUNT(*)
UNION ALL
SELECT 'column_b'
FROM table_name
WHERE `column_b` IS NOT NULL
HAVING COUNT(*)
-- etc.
(Може да се пропусне WHERE
клауза и заместник COUNT(*)
за COUNT(column)
, но мисля което може да е по-малко ефективно при индексирани колони).
Това може да стане чрез следното:
SET group_concat_max_len = 4294967295;
SELECT GROUP_CONCAT(
' SELECT ',QUOTE(COLUMN_NAME),
' FROM table_name',
' WHERE `',REPLACE(COLUMN_NAME, '`', '``'),'` IS NOT NULL',
' HAVING COUNT(*)'
SEPARATOR ' UNION ALL ')
INTO @sql
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_SCHEMA = DATABASE()
AND TABLE_NAME = 'table_name';
PREPARE stmt FROM @sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
Вижте го на sqlfiddle .