Résoudre l'ambiguïté SQL : le problème de la colonne « id »
Recevoir l'erreur « 1052 : La colonne 'id' dans la liste de champs est ambiguë » dans vos requêtes SQL ? Cela se produit lorsque votre instruction SELECT
inclut une colonne id
présente dans plusieurs tables jointes. La base de données ne peut pas déterminer quel id
vous avez l'intention de récupérer.
La solution est de spécifier la source du tableau pour chaque id
colonne. Cela peut être fait en utilisant soit le nom complet de la table, soit, plus efficacement, un alias de table.
Utilisation des noms de table complets :
Cette approche indique explicitement l'origine de la table de chaque id
:
<code class="language-sql">SELECT tbl_names.id, tbl_section.id, name, section FROM tbl_names JOIN tbl_section ON tbl_section.id = tbl_names.id</code>
Utilisation des alias de table (recommandé) :
Les alias de table raccourcissent la requête et améliorent la lisibilité :
<code class="language-sql">SELECT n.id, s.id, n.name, s.section FROM tbl_names AS n JOIN tbl_section AS s ON s.id = n.id</code>
Les deux méthodes obtiennent le même résultat, mais les alias sont généralement préférés pour leur concision.
Comprendre la syntaxe JOIN : ANSI-92 contre ANSI-89
Les exemples ci-dessus utilisent la syntaxe ANSI-92 JOIN
. Bien que fonctionnellement similaire à l'ancienne syntaxe ANSI-89 pour les INNER JOIN
simples, ANSI-92 est supérieur pour sa gestion plus claire des OUTER JOIN
(GAUCHE, DROITE, COMPLET). Pour la maintenabilité et pour exploiter toute la puissance des JOIN
opérations, ANSI-92 est la norme recommandée.
En qualifiant correctement les noms de vos colonnes et en utilisant la syntaxe ANSI-92 JOIN
moderne, vous éliminerez toute ambiguïté et écrirez des requêtes SQL plus efficaces et plus lisibles.
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!