Du bör använda IS NOT NULL
. (Jämförelseoperatorerna =
och <>
båda ger UNKNOWN
med NULL
på vardera sidan av uttrycket.)
SELECT *
FROM table
WHERE YourColumn IS NOT NULL;
Bara för fullständighetens skull ska jag nämna att i MySQL kan du också förneka null säker jämställdhetsoperatör men detta är inte standard SQL.
SELECT *
FROM table
WHERE NOT (YourColumn <=> NULL);
Redigerat för att återspegla kommentarer. Det låter som att din tabell kanske inte är i första normala form i vilket fall att ändra strukturen kan göra din uppgift lättare. Ett par andra sätt att göra det på...
SELECT val1 AS val
FROM your_table
WHERE val1 IS NOT NULL
UNION ALL
SELECT val2
FROM your_table
WHERE val2 IS NOT NULL
/*And so on for all your columns*/
Nackdelen med ovanstående är att den skannar tabellen flera gånger en gång för varje kolumn. Det kan möjligen undvikas av nedan men jag har inte testat detta i MySQL.
SELECT CASE idx
WHEN 1 THEN val1
WHEN 2 THEN val2
END AS val
FROM your_table
/*CROSS JOIN*/
JOIN (SELECT 1 AS idx
UNION ALL
SELECT 2) t
HAVING val IS NOT NULL /*Can reference alias in Having in MySQL*/