Maison >base de données >tutoriel mysql >COUNT(colonne) vs COUNT(*) : quelle est la différence en SQL ?

COUNT(colonne) vs COUNT(*) : quelle est la différence en SQL ?

Linda Hamilton
Linda Hamiltonoriginal
2025-01-13 14:52:42939parcourir

COUNT(column) vs. COUNT(*): What's the Difference in SQL?

La différence entre COUNT(column) et COUNT(*) en SQL

Question

Quelle est la différence entre COUNT(column) et COUNT(*) lors de l'interrogation de tables SQL ?

Explication

COUNT(column) compte le nombre de valeurs non nulles dans la colonne spécifiée. En revanche, COUNT(*) compte toutes les lignes d'un tableau, que la colonne spécifiée contienne ou non des valeurs nulles.

Exemple

Considérez la forme suivante :

id name
1 John Doe
2 Jane Doe
3 NULL
4 NULL

Comparaison de COUNT(name) et COUNT(*)

  • COUNT(name) : exclut les lignes contenant des valeurs NULL, ce qui donne 2.
  • COUNT(*) : contient des lignes contenant des valeurs NULL, ce qui donne 4.

Gestion des valeurs NULL

COUNT(column) ignore les valeurs NULL, tandis que COUNT(*) les traite comme des entrées valides. Ce comportement peut affecter les résultats de la requête, notamment lors de l'application de conditions à la clause WHERE.

Informations complémentaires

Considérez la requête suivante :

<code class="language-sql">SELECT name, COUNT(*)
FROM table
GROUP BY name
HAVING COUNT(*) > 2;</code>
  • En utilisant COUNT(*), le résultat contiendra une ligne de valeurs NULL et un nombre de valeurs NULL.
  • Avec COUNT(name), les valeurs NULL seront exclues, donc la ligne ne sera pas renvoyée dans le résultat.

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!

Déclaration:
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