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 :
SELECT logcount, logUserID, maxlogtm , DATEDIFF(day, maxlogtm, GETDATE()) AS daysdiff FROM statslogsummary WHERE daysdiff > 120
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 :
SELECT * FROM ( SELECT logcount, logUserID, maxlogtm, DATEDIFF(day, maxlogtm, GETDATE()) AS daysdiff FROM statslogsummary ) as innerTable WHERE daysdiff > 120
Méthode 2 : Utiliser le CTE
Vous pouvez également utiliser CTE comme dans l'exemple ci-dessous :
WITH CTE AS ( SELECT logcount, logUserID, maxlogtm, DATEDIFF(day, maxlogtm, GETDATE()) AS daysdiff FROM statslogsummary ) SELECT * FROM CTE WHERE daysdiff > 120
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!