IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Regrouper enregistrements liés


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Archéologue
    Inscrit en
    Mars 2019
    Messages
    134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Archéologue
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mars 2019
    Messages : 134
    Par défaut Regrouper enregistrements liés
    Bonjour à vous,

    j'ai deux bases MySQL Auteur et Biblio liées entre elles avec une liaison un à plusieurs. La liaison est opérée par une base intermédiaire qui enregistre les ID liées de chaque base (la base lien_auteur_biblio pour être original).

    En PHP, je sors un tableau qui doit m'afficher des données des deux tables liées mais je souhaiterais que les données liées soient rassemblées.
    Imaginons que ma table de liens aient ces enregistrements :
    Biblio1 Auteur1
    Biblio1 Auteur2
    Biblio1 Auteur3
    Biblio2 Auteur1
    Biblio3 Auteur4
    Eh ben je souhaiterais pouvoir avoir plutôt cette table en sortie :
    Biblio1 Auteur1;Auteur2;Auteur3
    Biblio2 Auteur1
    Biblio3 Auteur4
    Pour l'instant, j'ai réussi à regrouper les enregistrement par biblio en utilisant la fonction GROUP BY dans la requête SQL, mais je n'arrive pas concaténer les enregistrements liés (type Auteur1;Auteur2;Auteur3)
    Ma requête actuelle ressemble à ça :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT * from bibliographie 
    LEFT JOIN lien_auteur_biblio ON bibliographie.ID_Biblio=lien_auteur_biblio.ID_Biblio 
    LEFT JOIN auteur on lien_auteur_biblio.ID_Auteur=auteur.ID_Auteur
    GROUP BY bibliographie.ID_Biblio 
    ORDER BY Annee_Biblio DESC
    Je ne sais pas si j'ai été assez clair pour susciter à quelqu'un l'envie de me répondre...mais en tout cas je l'en remercie beaucoup d'avance !

  2. #2
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    salut,

    tu peux y arriver en utilisant GROUP_CONCAT() :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
      SELECT *, GROUP_CONCAT(auteur.ID_Auteur) AS 'liste_auteurs'
        FROM bibliographie 
             LEFT JOIN lien_auteur_biblio ON lien_auteur_biblio.ID_Biblio = bibliographie.ID_Biblio
             LEFT JOIN auteur             ON lien_auteur_biblio.ID_Auteur = auteur.ID_Auteur
    GROUP BY bibliographie.ID_Biblio 
    ORDER BY Annee_Biblio DESC

  3. #3
    Membre confirmé
    Homme Profil pro
    Archéologue
    Inscrit en
    Mars 2019
    Messages
    134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Archéologue
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mars 2019
    Messages : 134
    Par défaut
    Super, c'est nickel merci !

  4. #4
    Membre confirmé
    Homme Profil pro
    Archéologue
    Inscrit en
    Mars 2019
    Messages
    134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Archéologue
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mars 2019
    Messages : 134
    Par défaut
    petite question subsidiaire : est-il possible d'ordonner cette liste concaténée ?

  5. #5
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    le mieux c'est que tu essaies directement, non ?
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
      SELECT *, GROUP_CONCAT(auteur.ID_Auteur ORDER BY auteur.ID_Auteur ASC) AS 'liste_auteurs'
        FROM bibliographie 
             LEFT JOIN lien_auteur_biblio ON lien_auteur_biblio.ID_Biblio = bibliographie.ID_Biblio
             LEFT JOIN auteur             ON lien_auteur_biblio.ID_Auteur = auteur.ID_Auteur
    GROUP BY bibliographie.ID_Biblio 
    ORDER BY Annee_Biblio DESC

  6. #6
    Membre confirmé
    Homme Profil pro
    Archéologue
    Inscrit en
    Mars 2019
    Messages
    134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Archéologue
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mars 2019
    Messages : 134
    Par défaut
    ah je suis désolé rawsrc, j'avais bien testé en intégrant le order by, mais je ne l'avais juste pas mis à l'intérieur des parenthèses.
    Merci beaucoup !!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 7
    Dernier message: 26/09/2012, 19h44
  2. Ajouter des enregistrements liés dans des tables
    Par nounadevelop dans le forum Modélisation
    Réponses: 6
    Dernier message: 13/01/2009, 19h53
  3. Requête d'édition des enregistrements liés à un autre
    Par zakuli dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 17/04/2007, 17h44
  4. Réponses: 1
    Dernier message: 14/07/2006, 17h23
  5. Liste déroulante + enregistrements liés...
    Par Invité dans le forum ASP
    Réponses: 2
    Dernier message: 03/08/2005, 16h57

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo