Maison >base de données >tutoriel mysql >Comment puis-je récupérer uniquement des valeurs non nulles dans MySQL à l'aide des instructions SELECT ?
Instruction MySQL SELECT : récupération de données non nulles
Ce guide montre comment récupérer efficacement uniquement les valeurs non nulles de vos tables de base de données MySQL à l'aide des instructions SELECT
. La méthode la plus simple et la plus courante utilise la condition IS NOT NULL
.
Méthode 1 : Utiliser IS NOT NULL
La clause IS NOT NULL
filtre directement les lignes où la colonne spécifiée contient une valeur NULL
.
Exemple :
<code class="language-sql">SELECT * FROM your_table WHERE your_column IS NOT NULL;</code>
Méthode 2 : Utilisation de NOT et de l'opérateur d'égalité Null-Safe
MySQL prend en charge une approche non standard utilisant l'opérateur NOT
avec l'opérateur d'égalité null-safe (<=>
). Bien que fonctionnel, IS NOT NULL
est généralement préféré pour une meilleure lisibilité et une conformité à la norme SQL.
<code class="language-sql">SELECT * FROM your_table WHERE NOT (your_column <=> NULL);</code>
Méthode 3 : UNION ALL pour plusieurs colonnes
Pour les tables comportant plusieurs colonnes, une instruction UNION ALL
offre un moyen de récupérer les valeurs non nulles de chaque colonne individuellement. Cette méthode est moins efficace que l'utilisation de IS NOT NULL
sur chaque colonne d'une seule requête, mais elle peut être utile dans des scénarios spécifiques.
<code class="language-sql">SELECT col1 AS value FROM your_table WHERE col1 IS NOT NULL UNION ALL SELECT col2 FROM your_table WHERE col2 IS NOT NULL -- Add more UNION ALL clauses for additional columns</code>
Méthode 4 : Instruction CASE avec CROSS JOIN et HAVING
Une approche plus complexe, mais potentiellement utile, consiste à utiliser une instruction CASE
, CROSS JOIN
et HAVING
. Cette méthode est généralement moins efficace que les méthodes plus simples mais apporte une solution alternative.
<code class="language-sql">SELECT CASE idx WHEN 1 THEN col1 WHEN 2 THEN col2 END AS value FROM your_table CROSS JOIN ( SELECT 1 AS idx UNION ALL SELECT 2 ) t HAVING value IS NOT NULL;</code>
N'oubliez pas de remplacer your_table
et your_column
(ou col1
, col2
, etc.) par les noms réels de vos tables et colonnes. La méthode IS NOT NULL
est généralement recommandée pour sa simplicité et son efficacité.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!