Jointure de table complexe sql

ideal23 Messages postés 505 Statut Membre -  
vordano Messages postés 1981 Statut Membre -
Bonjour,
voici mon problème, que je n'arrive pas à résoudre. J'ai fait une requête sql pour afficher le résultat de la jointure de 2 tables. Mais il me manque l'affichage d'un champ.
les tables:
menu
http://creuselimousin.free.fr/tablepetite.jpg
articles
http://creuselimousin.free.fr/articles.jpg
ma requête:
SELECT articles.titre, articles.'description', articles.prix, articles.photo, menu.id_menu, menu.item_menu, menu.id_menu_dir, articles.reference
FROM articles, menu
WHERE articles.ref_menu=menu.id_menu
ORDER BY id_menu ASC


les champs voulus de la table articles sont visibles, les champs sous menus de la table menu également, mais il manque les champs du menu principal, identifiés par id_menu_dir.

une image pour expliquer ma demande:
http://creuselimousin.free.fr/requete1.jpg
j'ai essayé avec une autre requete:
SELECT articles.reference,articles.prix,articles.description,articles.titre,m1.id_menu,m1.item_menu,m2.id_menu,m2.item_menu
FROM articles
  INNER JOIN menu AS m1 ON m1.id_menu = articles.ref_menu
 INNER JOIN menu AS m2 ON m2.id_menu = m1.id_menu_dir 

là c'est le contraire j'ai les éléments du menu principal, pas des sous menus, j'ai dû faire une erreur.
Avez-vous une idée pour construire cette requête. Merci

8 réponses

  1. Anoen Messages postés 200 Statut Membre 25
     
    Bonjour,

    Dans le SELECT tu ne lui demande pas de récupérer id_menu_dir
    0
  2. ideal23 Messages postés 505 Statut Membre 28
     
    j'ai pensé à cette requête
    SELECT articles.reference,articles.titre,m1.id_menu,m1.item_menu,m2.id_menu,m2.item_menu
    FROM articles
    INNER JOIN menu AS m1 ON m1.id_menu = articles.ref_menu
    INNER JOIN menu AS m2 ON m2.id_menu = m1.id_menu_dir

    mais çà ne fonctionne pas
    0
  3. vordano Messages postés 1981 Statut Membre 316
     
    bonjour,

    est ce qu'il serais possible d'avoir une exportation de ces deux tables (structure+donnée) dans un fichier.sql ? (histoire de faire les tests pour trouver l'erreur, parce qu'à priori ta première requète est correcte)
    0
  4. ideal23 Messages postés 505 Statut Membre 28
     
    oui bien sûr
    http://creuselimousin.free.fr/articles.sql
    http://creuselimousin.free.fr/menu.sql
    0
  5. Vous n’avez pas trouvé la réponse que vous recherchez ?

    Posez votre question
  6. vordano Messages postés 1981 Statut Membre 316
     
    après quelques test, voici ce que j'ai obtenu:
    SELECT titre,m1.item_menu as 'menu parent', m2.item_menu as 'menu enfant'
    FROM menu m1, menu m2,articles
    WHERE m1.id_menu=m2.id_menu_dir
    and ref_menu=m2.id_menu

    j'ai évidemment supprimé toutes les colonnes superflu de la requètes, mais je pense que ça doit correspondre à ta demande.
    0
  7. ideal23 Messages postés 505 Statut Membre 28
     
    Merci vordano, efficace, et rapide. Ta requête fonctionne parfaitement. çà correspond bien à ma demande, bonne soirée et encore Merci
    0
  8. ideal23 Messages postés 505 Statut Membre 28
     
    Une question à propos de cette requête. Peut-on passer une variable d'url avec $_GET facilement pour afficher le résultat des différents éléments du menu à chaque clique.
    exemple :pour carrelage intérieur et les 2 sous menus correspondants, affichage des 4 données de la table articles, ainsi de suite.
    0
  9. vordano Messages postés 1981 Statut Membre 316
     
    $req="SELECT titre,m1.item_menu as 'menu parent', m2.item_menu as 'menu enfant'
    FROM menu m1, menu m2,articles
    WHERE m1.id_menu=m2.id_menu_dir
    and ref_menu=m2.id_menu
    and titre='".$_GET['titre']."';";


    et voilà, ça te va ?
    0