Précédent   Forum des professionnels en informatique > PHP > Langage > Débuter
Débuter Forum d'entraide pour débuter en PHP. Avant de poster -> Cours PHP, FAQ PHP, Outils PHP, etc.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 03/03/2011, 21h21   #1
Invité de passage
 
sandrine
Inscription : février 2011
Messages : 11
Détails du profil
Informations personnelles :
Nom : sandrine

Informations forums :
Inscription : février 2011
Messages : 11
Points : 1
Points : 1
Par défaut jointure sur plusieurs tables pour faire un menu

Bonjour,

J'essaye de faire une jointure sur plusieurs tables afin de faire un menu avec plusieurs niveaux de sous menus (jusqu'à 4).
J'ai une table par niveau de menu (menuNiv1, menuNiv2, menuNiv3 et menuNiv4) et dans chaque table une colonne qui fait le lien avec la table précédente.
J'ai essayé, entre autre, ce code, qui n'affiche rien du tout :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
 
$base=connectBDD();
$reponse = $base->query
		('
		SELECT 			n1.itemMenu AS itemMenu1, n2.itemMenu AS itemMenu2, n3.itemMenu AS itemMenu3, n4.itemMenu AS itemMenu4
		FROM 			menuNiv1 AS n1
		LEFT JOIN		menuNiv2 AS n2
		ON			itemMenu1 = n2.idParent
		LEFT jOIN		menuNiv3 AS n3
		ON			n2.id = n3.idParent
		LEFT JOIN		menuNiv4 AS n4
		ON			n3.id = n4.idParent
		');
$tabMenus = array();
 
while ($donnees = $reponse->fetch())
	{		
		$tabMenus[] = array(
		'menu1' => $donnees['itemMenu1'],
		'menu2' => $donnees['itemMenu2'],
		'menu3' => $donnees['itemMenu3'],
		'menu4' => $donnees['itemMenu4']
		);
	}	
echo $tabMenus[0]['menu1'];
$reponse->closeCursor();
closeBDD();
Pour le moment, pour simplifier, je pourrais déjà me limiter à essayer de faire la jointure sur les 2 premières tables uniquement, comme ça (mais ça ne marche pas non plus) :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
 
$base=connectBDD();
$reponse = $base->query
		('
		SELECT 			n1.itemMenu AS itemMenu1, n2.itemMenu AS itemMenu2, n3.itemMenu AS itemMenu3, n4.itemMenu AS itemMenu4
		FROM 			menuNiv1 AS n1
		LEFT JOIN		menuNiv2 AS n2
		ON			itemMenu1 = n2.idParent
		');
$tabMenus = array();
 
while ($donnees = $reponse->fetch())
	{		
		$tabMenus[] = array(
		'menu1' => $donnees['itemMenu1'],
		'menu2' => $donnees['itemMenu2']
		);
	}	
echo $tabMenus[0]['menu1'];
 
$reponse->closeCursor();
closeBDD();
Est-ce que quelqu'un peut m'aider à trouver l'erreur (ou les erreurs) ?
Merci!
labobinette est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/03/2011, 21h36   #2
Modérateur
 
Avatar de sabotage
 
Homme Vincent
Inscription : juillet 2005
Messages : 14 929
Détails du profil
Informations personnelles :
Nom : Homme Vincent

Informations forums :
Inscription : juillet 2005
Messages : 14 929
Points : 16 381
Points : 16 381
Ta méthode n'est pas bonne.
Utilise une seule table en gardant ton système parent/enfant
ou une représentation intervallaire :
http://sqlpro.developpez.com/cours/arborescence/

Pour tes requêtes actuelles, commence par afficher les erreurs : dans ta deuxieme mouture, tu as laissé les champs de 4 tables.
sabotage est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/03/2011, 15h42   #3
Invité de passage
 
sandrine
Inscription : février 2011
Messages : 11
Détails du profil
Informations personnelles :
Nom : sandrine

Informations forums :
Inscription : février 2011
Messages : 11
Points : 1
Points : 1
Merci pour ta réponse,

En effet je n'avais pas affiché les erreurs.
Je viens de découvrir – et oui ! – qu'il fallait les activer dans le fichier php.ini
C'est certainement la base de chez base, mais je ne savais pas. Alors évidemment pas facile de trouver d'où viennent les problèmes.
Pour ceux qui serait dans le même cas que moi (je suis dans mamp):
Il faut, dans ce fichier :
mamp/php5/php.ini
mettre la ligne display_errors sur On
Code :
1
2
3
4
5
6
7
 
; Print out errors (as a part of the output).  For production web sites,
; you're strongly encouraged to turn this feature off, and use error logging
; instead (see below).  Keeping display_errors enabled on a production web site
; may reveal security information to end users, such as file paths on your Web
; server, your database schema or other information.
display_errors = On
Sinon, j'ai corrigé le code dans la seconde mouture et ça marche :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
 
$base=connectBDD();
$reponse = $base->query('
		SELECT 		n1.itemMenu AS itemMenu1, n2.itemMenu AS itemMenu2 
		FROM 		menuNiv1 AS n1 
		LEFT JOIN	menuNiv2 AS n2 
		ON 			n1.itemMenu = n2.idParent
		');
$tabMenus = array();
 
while ($donnees = $reponse->fetch())
	{		
		$tabMenus[] = array(
		'menu1' => $donnees['itemMenu1'],
		'menu2' => $donnees['itemMenu2']
		);
	}	
echo $tabMenus[0]['menu1'];
 
$reponse->closeCursor();
closeBDD();
Pour info, ça marche aussi avec un travail sur plus de deux tables…

Et sinon, vu que ce n'est pas la bonne méthode,
dès que j'ai une minute, je vais aller étudier ton lien et je viendrais poster ici
la solution avec "la bonne méthode".

Merci beaucoup pour ton aide, Sabotage !
labobinette est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 04/03/2011, 16h10   #4
Modérateur
 
Avatar de Benjamin Delespierre
 
Benjamin Delespierre
Développeur Web
Inscription : février 2010
Messages : 2 984
Détails du profil
Informations personnelles :
Nom : Benjamin Delespierre
Âge : 24
Localisation : France

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Opérateur de télécommunications

Informations forums :
Inscription : février 2010
Messages : 2 984
Points : 5 014
Points : 5 014
Au passage, voici un article de MySQL qui traite de ce problème de modélisation bien connu: http://dev.mysql.com/tech-resources/...ical-data.html
__________________
A la recherche d'un framework MVC facile a prendre en main ? Essayez Axiom
Nouveau: la référence d'Axiom est disponible sur GitHub (je la peaufine en ce moment même).

Un problème correctement identifié est à moitié résolu, évitez de poster l'intégralité de votre code avec pour seule explication "ça ne marche pas...".
Pour identifier correctement vos problèmes PHP, utilisez la gestion des erreurs et xdebug.

Les boutons et existent, servez-vous en
Benjamin Delespierre est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 15h40.


 
 
 
 
Partenaires

Hébergement Web