Maison > base de données > tutoriel mysql > Quelle est la différence entre la valeur null de MySQL et NULL ? (avec des exemples)

Quelle est la différence entre la valeur null de MySQL et NULL ? (avec des exemples)

不言
Libérer: 2019-02-14 13:12:29
avant
5041 Les gens l'ont consulté


Ce que cet article vous apporte, c'est quelle est la différence entre la valeur nulle de MySQL et NULL ? (Avec des exemples), il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il vous sera utile.

La différence essentielle :

1. Les valeurs nulles n'occupent pas d'espace

2. occuper de l'espace

En termes simples :

Une valeur nulle est comme une tasse de transition sous vide sans rien dedans, tandis qu'une valeur nulle est une tasse remplie d'air bien qu'elles se ressemblent toutes, ils ont une différence essentielle.

(Cours recommandé : Tutoriel MySQL)

Exemple :

Créer une table de test, colA ne peut pas stocker de valeurs nulles, colB peut stocker des valeurs nulles.

CREATE TABLE `test` (
   `colA` varchar(255) NOT NULL,
   `colB` varchar(255) DEFAULT NULL
 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
Copier après la connexion

Essayez d'insérer une valeur nulle. Que se passera-t-il ?

INSERT INTO `test`(`colA`, `colB`) VALUES (NULL, NULL);
Copier après la connexion

//Une erreur se produit car colA ne peut pas insérer de valeurs nulles.

Alors, que se passe-t-il si des valeurs nulles sont insérées dans deux champs en même temps.

INSERT INTO `test`(`colA`, `colB`) VALUES ('', '');
Copier après la connexion

L'insertion est réussie, indiquant que même lorsque le champ est défini sur une valeur nulle, des valeurs nulles peuvent être insérées

- ----- --------------------------------------------- ----- ------Requête-------------------------------------- ----------- ----------------

Il y a maintenant trois données dans le tableau

Ensuite, nous utilisons n'est pas nul et < ;> Récupérons les données dans la table de données

1 Requête en utilisant IS NOT NULL

1 SELECT * FROM `test` WHERE colA IS NOT NULL
Copier après la connexion

1 SELECT * FROM `test` WHERE colB IS NOT NULL
Copier après la connexion

Conclusion : L'utilisation de la requête IS NOT NULL ne filtrera pas les valeurs nulles, mais elle filtrera NUL.

2. Requête en utilisant <>

1 SELECT * FROM `test` WHERE colA <> &#39;&#39;;
Copier après la connexion
Copier après la connexion


Conclusion :

L'utilisation de <> filtrera les valeurs NULL et vides.

1 SELECT * FROM `test` WHERE colA <> &#39;&#39;;
Copier après la connexion
Copier après la connexion

3. Utilisez le nombre pour interroger

Conclusion :
1 SELECT COUNT(colA) FROM `test`;
Copier après la connexion
L'utilisation de count filtrera les valeurs NULL, mais elle ne filtrera pas les valeurs NULL.

1 SELECT COUNT(colB) FROM `test`;
Copier après la connexion
Résumé

1. Les valeurs nulles n'occupent pas d'espace et les valeurs NULL occupent de l'espace (un octet).

2. Lorsque le champ n'est pas NULL, vous pouvez également insérer une valeur nulle.

3. Lorsque vous utilisez IS NOT NULL ou IS NULL, vous pouvez uniquement vérifier qu'il n'y a pas de valeur non NULL ou NULL dans le champ, mais vous ne pouvez pas vérifier les valeurs nulles.

4. Lorsque vous utilisez <> pour interroger, les valeurs vides et les valeurs NULL seront filtrées.

5. Lors de l'utilisation des statistiques de comptage, les valeurs NULL seront filtrées, mais les valeurs NULL ne seront pas filtrées.

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!

Étiquettes associées:
source:cnblogs.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal