Résoudre l'ambiguïté des colonnes dans les requêtes MySQL à partir de plusieurs tables avec une structure similaire
Le scénario de base de données fourni implique plusieurs tables avec des structures de données identiques, chacune servant à des fins de localisation spécifiques. Bien que la récupération des données d'une seule table ne présente aucun problème, la tâche devient difficile lors de la combinaison des données de plusieurs tables et du tri selon une colonne personnalisée. L'erreur rencontrée, "La colonne 'genre' dans la clause WHERE est ambiguë", provient de l'incapacité de MySQL à faire la distinction entre la colonne 'genre' des différentes tables de la clause WHERE.
Pour résoudre cette ambiguïté et obtenir l'objectif souhaité Pour la récupération des données, la clause UNION doit être utilisée. La clause UNION vous permet de combiner les résultats de deux ou plusieurs requêtes en un seul jeu de résultats. Dans ce cas, des requêtes distinctes peuvent être utilisées pour récupérer les données de chaque table en fonction de la condition de « genre » spécifiée, puis la clause UNION peut combiner ces résultats.
Voici la déclaration MySQL révisée utilisant la clause UNION :
(SELECT * FROM us_music WHERE `genre` = 'punk') UNION (SELECT * FROM de_music WHERE `genre` = 'punk')
Cette requête sélectionnera d'abord toutes les lignes de la table 'us_music' où la colonne 'genre' est égale à 'punk'. Il sélectionnera ensuite toutes les lignes de la table 'de_music' avec la même condition 'genre'. L'opérateur UNION combinera ensuite ces deux ensembles de résultats, garantissant ainsi la suppression des lignes en double.
En employant la clause UNION, la requête élimine efficacement l'ambiguïté des colonnes et vous permet d'accéder et de trier les données de plusieurs tables avec des valeurs similaires. structures de manière transparente.
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!