Maison  >  Article  >  base de données  >  Colonne inconnue 'nom_colonne' dans 'clause on' - Comment résoudre l'erreur MySQL : colonne inconnue dans la clause on

Colonne inconnue 'nom_colonne' dans 'clause on' - Comment résoudre l'erreur MySQL : colonne inconnue dans la clause on

王林
王林original
2023-10-05 08:13:241605parcourir

Unknown column 'column_name' in 'on clause' - 如何解决MySQL报错: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 :

  1. Confirmez si le nom de la colonne est correctement orthographié : Tout d'abord, nous devons soigneusement vérifier si le nom de la colonne dans le code est orthographié de manière cohérente avec le nom de la colonne dans la table de la base de données, en faisant attention si la casse correspond. . S'ils sont incohérents, vous devez modifier les noms de colonnes dans le code avec l'orthographe correcte.

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;

  1. Confirmer la colonne Si le nom est défini dans le bon tableau : Si nous confirmons qu'il n'y a pas de problème avec l'orthographe du nom de la colonne, nous devons nous assurer qu'il est défini dans le tableau correspondant. De même, vérifiez que les noms de table et de colonne correspondent aux définitions de la base de données.

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;

  1. Utilisez la table Soyez prudent avec les citations lors de la création d'alias : parfois, des alias de table sont utilisés dans les requêtes de jointure pour simplifier le code. Cependant, lors de l'utilisation d'alias de table, cette erreur peut également survenir si le préfixe d'alias n'est pas utilisé correctement lors de la référence aux noms de colonnes dans la clause on.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn