Maison >base de données >tutoriel mysql >Colonne inconnue 'nom_colonne' dans 'clause on' - Comment résoudre l'erreur MySQL : colonne inconnue dans la clause on
Titre : Colonne inconnue 'nom_colonne' dans 'clause on' - Comment résoudre l'erreur MySQL : colonne inconnue dans la clause on, des exemples de code spécifiques sont nécessaires
Texte de l'article :
MySQL est une base de données relationnelle open source couramment utilisée Les systèmes de gestion sont largement utilisés dans divers types de développement d'applications. Cependant, lors de l'utilisation de MySQL, vous rencontrez parfois diverses erreurs et problèmes. L'une des erreurs courantes est "Colonne inconnue 'nom_colonne' dans la clause on" (colonne inconnue dans la clause on).
Lorsque nous exécutons une instruction de requête de jointure (JOIN) dans MySQL et qu'un nom de colonne inconnu est référencé dans la clause on, MySQL signalera cette erreur. Cette erreur est généralement provoquée par une faute d'orthographe d'un nom de colonne, un nom de colonne qui n'est pas défini dans la table correspondante ou une utilisation incorrecte d'un alias.
Alors, comment résoudre ce problème ? Voici quelques solutions courantes :
Par exemple, disons que nous avons une table appelée « utilisateurs » qui contient des colonnes nommées « id » et « name ». Cette erreur sera signalée si nous épelons le nom de colonne « id » comme « Id » dans la requête de jointure. La bonne façon de l'écrire est de changer le nom de la colonne "id" en "Id".
SELECT *
FROM utilisateurs
JOIN commandes SUR utilisateurs.Id = commandes.user_id;
La bonne façon de l'écrire est :
SELECT *
FROM utilisateurs
JOIN commandes SUR utilisateurs.id = commandes.user_id;
Par exemple, disons que nous avons une table appelée « commandes » qui contient une colonne nommée « user_id ». Mais si nous écrivons le nom de colonne « user_id » comme « customer_id » dans la requête de connexion, cette erreur sera signalée. À ce stade, nous devons modifier le nom de la colonne avec l’orthographe correcte.
SELECT *
FROM utilisateurs
JOIN commandes SUR utilisateurs.id = commandes.customer_id;
La bonne façon de l'écrire est :
SELECT *
FROM utilisateurs
JOIN commandes SUR utilisateurs.id = commandes.user_id;
Par exemple, supposons que nous utilisions des alias de table pour simplifier le code :
SELECT *
FROM users AS u
JOIN commandes AS o ON u.id = commandes.user_id;
À ce stade, référencez la colonne dans le Clause on Lors de la dénomination, nous devons utiliser le préfixe d'alias correct "u" au lieu du nom de table d'origine "users".
Grâce aux méthodes ci-dessus, nous pouvons résoudre le problème de l'erreur MySQL "Colonne inconnue 'nom_colonne' dans la clause on" (colonne inconnue dans la clause on). Dans le même temps, afin de mieux comprendre cette erreur et la solution, un exemple de code spécifique est donné ci-dessous :
Exemple de code :
CREATE TABLE utilisateurs (
id INT PRIMARY KEY,
nom VARCHAR(50)
) ;
CREATE TABLE commandes (
id INT PRIMARY KEY,
user_id INT,
order_date DATE
);
INSERT INTO utilisateurs VALUES (1, 'Alice');
INSERT INTO utilisateurs VALUES (2, 'Bob');
INSÉRER DANS LES VALEURS des commandes (1, 1, '2022-01-01');
INSÉRER DANS LES VALEURS des commandes (2, 2, '2022-01-02'); id = commandes.user_id;
Dans cet exemple, nous créons une table nommée « utilisateurs » et une table nommée « commandes », et elles sont connectées par ID utilisateur. Dans la requête de jointure, nous avons utilisé les noms de colonnes et les préfixes d’alias corrects pour éviter les erreurs.
Pour résumer, pour résoudre l'erreur MySQL "Colonne inconnue 'nom_colonne' dans 'clause on'", vous devez faire attention à l'orthographe du nom de la colonne, si le nom de la colonne a été défini dans la table, et au méthode de référence lors de l’utilisation d’alias. En vérifiant soigneusement et en modifiant correctement le code, nous pouvons éviter cette erreur et exécuter avec succès l'instruction de requête de jointure.
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!