Maison >base de données >tutoriel mysql >Puis-je utiliser des alias de colonne dans la clause WHERE de MySQL ?
Utiliser des alias dans la clause MySQL WHERE
Dans MySQL, les alias sont souvent utilisés pour donner des noms temporaires aux colonnes dérivées. Bien que pratiques pour référence, leur utilisation dans une clause WHERE peut provoquer des erreurs.
MySQL restreint le référencement des alias de colonnes dans la clause WHERE. En effet, la valeur de la colonne n'est peut-être pas encore déterminée lorsque la clause WHERE est exécutée. Par conséquent, spécifier un alias dans la clause WHERE déclenchera une erreur « colonne inconnue ».
Solution
Pour surmonter cette limitation, il existe plusieurs solutions de contournement :
<code class="language-sql">HAVING avg_rating > 5</code>
<code class="language-sql">WHERE (sum(reviews.rev_rating)/count(reviews.rev_id)) > 5</code>
Restrictions
Veuillez noter que toutes les expressions ne sont pas autorisées dans la clause WHERE. Les fonctions d'agrégation comme SUM nécessitent la clause HAVING.
Comme indiqué dans le manuel MySQL :
"Les références aux alias de colonne dans une clause WHERE ne sont pas autorisées car la valeur de la colonne peut ne pas avoir été déterminée lors de l'exécution de la clause WHERE."
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!