Maison >base de données >tutoriel mysql >Puis-je utiliser des alias de colonne dans une clause WHERE ?
Référez-vous à l'alias de la colonne dans la clause WHERE
La requête SQL suivante utilise des alias de colonnes dans la clause WHERE :
<code class="language-sql">SELECT logcount, logUserID, maxlogtm , DATEDIFF(day, maxlogtm, GETDATE()) AS daysdiff FROM statslogsummary WHERE daysdiff > 120</code>
L'exécution de cette requête entraînera une erreur : "Nom de colonne invalide joursdiff". En effet, les alias de colonnes comme daydiff ne sont généralement pas accessibles directement dans la clause WHERE.
Pour résoudre ce problème, nous pouvons forcer SQL à exécuter d'abord l'instruction SELECT, puis la clause WHERE. Ceci peut être réalisé en utilisant des parenthèses ou des expressions de table communes (CTE).
Méthode 1 : Utiliser des parenthèses
Dans la requête modifiée ci-dessous, l'instruction SELECT est mise entre parenthèses, la forçant à s'exécuter avant la clause WHERE :
<code class="language-sql">SELECT * FROM ( SELECT logcount, logUserID, maxlogtm, DATEDIFF(day, maxlogtm, GETDATE()) AS daysdiff FROM statslogsummary ) as innerTable WHERE daysdiff > 120</code>
Méthode 2 : Utiliser le CTE
Vous pouvez également utiliser CTE comme dans l'exemple ci-dessous :
<code class="language-sql">WITH CTE AS ( SELECT logcount, logUserID, maxlogtm, DATEDIFF(day, maxlogtm, GETDATE()) AS daysdiff FROM statslogsummary ) SELECT * FROM CTE WHERE daysdiff > 120</code>
En utilisant des parenthèses ou des CTE, vous pouvez contrôler l'ordre logique des opérations SQL, vous permettant de référencer les alias de colonnes dans les clauses WHERE et de résoudre ces erreurs.
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!