Maison >base de données >tutoriel mysql >Comment puis-je conserver l'ordre des tableaux lors de la jointure de tables dans PostgreSQL ?
Préserver l'ordre dans PostgreSQL JOIN avec les types de tableaux : une solution complète
Le schéma de base de données donné se compose de deux tables : items et some_chosen_data_in_order. La tâche à accomplir est de récupérer les données de la table items pour une ligne spécifique de la table some_chosen_data_in_order tout en préservant l'ordre des éléments dans le champ de type de tableau.
Tentatives inefficaces :
Vos tentatives initiales d'utilisation de JOIN et de sous-requêtes n'ont pas réussi à maintenir l'ordre des éléments dans le champ de type de tableau. Ces approches ne préservent pas systématiquement l'ordre dans lequel les éléments apparaissent dans le tableau id_items.
Solution efficace :
Pour résoudre ce problème, utilisez une approche alternative impliquant le désimbriquer() function :
SELECT t.* FROM unnest(ARRAY[1,2,3,2,3,5]) item_id LEFT JOIN items t on t.id=item_id
Explication :
Cette requête exploite la fonction unnest() pour extraire des éléments individuels du tableau item_id, créant ainsi des lignes temporaires pour chaque élément. Par la suite, nous effectuons un LEFT JOIN avec la table items pour récupérer les données souhaitées tout en conservant l'ordre spécifié.
Exemple :
Considérons la table some_chosen_data_in_order contenant une ligne avec id_items comme [1,2,3,2,3,5]. L'exécution de la requête susmentionnée renverra les données relatives aux éléments suivants (dans l'ordre spécifié) :
Cette solution garantit que les données récupérées de la table items s'alignent sur l'ordre des éléments dans le champ type de tableau de la table some_chosen_data_in_order.
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!