Fonctions GROUP BY et agrégation de SQL : pièges courants
La clause GROUP BY
de SQL est puissante pour résumer les données, mais elle provoque souvent de la confusion, notamment concernant les colonnes qui peuvent apparaître dans l'instruction SELECT
.
Une erreur fréquente consiste à essayer de sélectionner des colonnes non agrégées sans les inclure dans la clause GROUP BY
. Par exemple :
<code class="language-sql">SELECT * FROM order_details GROUP BY order_no;</code>
Cette requête échouera. Lors de l'utilisation de GROUP BY
, toute colonne non soumise à une fonction d'agrégation (comme SUM
, COUNT
, AVG
, MIN
, MAX
) doit être incluse dans le GROUP BY
liste.
Pour corriger cela, soit incluez toutes les colonnes non agrégées dans la clause GROUP BY
:
<code class="language-sql">SELECT order_no, order_price FROM order_details GROUP BY order_no, order_price;</code>
Ou utilisez des fonctions d'agrégation pour résumer les données de chaque groupe :
<code class="language-sql">SELECT order_no, SUM(order_price) AS total_price FROM order_details GROUP BY order_no;</code>
Les fonctions d'agrégation calculent une seule valeur par groupe, vous permettant de récupérer des informations résumées même si vous ne répertoriez pas chaque colonne dans la clause GROUP BY
. Ceci est essentiel pour éviter les erreurs et obtenir des résultats significatifs à partir de données groupées. Le principe de base est le suivant : toutes les colonnes de la liste SELECT
doivent être soit agrégées, soit présentes dans la clause GROUP BY
.
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!