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 :

Requete imbriquée comment faire [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de spawns
    Homme Profil pro
    Inscrit en
    Juillet 2004
    Messages
    558
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 558
    Par défaut Requete imbriquée comment faire
    Salut à tous,
    petit soucis pour lister une bdd dans l'ordre que je veux, j'explique

    j'ai une requête qui me récupère des id dans une bdd programme
    ensuite j'ai une autre requête qui utilise ces id pour construire un tableau.

    le problème c'est que, comme la second requête et dans la première boucle cela me créer le tableau
    id par id et je ne peux pas le "ORDER BY" comme je veux.

    Avec le code cela sera peut être plus compréhensible

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    /*requête de recup des ID dans la bdd programme*/
    $requete27 ="SELECT p.id,d.userID FROM  programme p	INNER JOIN droit d ON p.id = d.programmeID WHERE d.userID ='$_SESSION Smiley id ' GROUP BY p.id ORDER BY p.id DESC";
    $ret27 = mysql_query($requete27);
    while($data27 = mysql_fetch_array($ret27)) 	
    		{	
    	$progid27=$data27['id'];
    /*requête de construction du tableau dans la bdd logement a l'aide des id précédemment récupérer dans la bdd programme*/
    $requete28 = "SELECT * FROM logement WHERE programme_ID=$progid27 ORDER BY type DESC"; 
    	$ret28 = mysql_query($requete28);
    	while($data28 = mysql_fetch_array($ret28))
    {
    	/* création du tableau ICI */
    	}
    	}
    je pense qu'il faut faire une requete imbriquée, mais la c'est un peu compliqué pour moi, si qql'un pouvait me donner un petit coup de main cela serait bien cool...
    Merci

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Fais une jointure avec logement directement dans ta première requête et oublie les boucles imbriquées.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut réponse
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT p.id, l.type, p.meschamps, l.mesautreschamps, ,d.userID FROM  programme p    
    INNER JOIN 
       droit d ON p.id = d.programmeID 
    INNNER JOIN 
       logement l ON l.programme_ID=p.id
    WHERE 
      d.userID ='$_SESSION Smiley id ' GROUP BY p.id 
    ORDER BY p.id, p.type DESC
    In one shot.
    un truc du genre

    Olivier

  4. #4
    Membre éclairé Avatar de spawns
    Homme Profil pro
    Inscrit en
    Juillet 2004
    Messages
    558
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 558
    Par défaut
    Merci nathieb
    mais la requête ne m'affiche rien
    voici les tables
    droit :
    id | programmeID | userID
    logement :
    id | programme_ID | promoteur | ville | residence | lot | type ....
    programme :
    id | promoteur | nom | synthese | description ...
    user :
    id | Login | mail | pass ...

    voila ce que j'ai écrit pour simplifier

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $requete28="SELECT p.id, l.programme_ID, d.userID FROM  programme p    
    INNER JOIN 
       droit d ON p.id = d.programmeID 
    INNNER JOIN 
       logement l ON l.programme_ID=p.id
    WHERE 
      d.userID ='$_SESSION[id] ' GROUP BY p.id 
    ORDER BY p.id DESC";
    Mais rien ne s'affiche

  5. #5
    Membre Expert Avatar de nathieb
    Homme Profil pro
    DevOps
    Inscrit en
    Mai 2004
    Messages
    1 058
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : DevOps
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 058
    Par défaut sans clause where
    Bonjour,

    Déjà essaye sans clause where pour comprendre la requête, c'est quoi le résultat ?

    Il y a un espace dans
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    d.userID ='$_SESSION[id] '
    est ce normal ?

    olivier

  6. #6
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    INNNER JOIN

    Il faut éviter de copier-coller sans lire ni comprendre...

  7. #7
    Membre éclairé Avatar de spawns
    Homme Profil pro
    Inscrit en
    Juillet 2004
    Messages
    558
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 558
    Par défaut
    Ahhrrr, c'est bon j'avais as vu,
    il y a 3 N dans le deuxieme INNER JOIN

    oh le boulet

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

Discussions similaires

  1. Requete SQL : comment faire un cumul
    Par yannick069 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 09/04/2015, 13h21
  2. Requete XML, comment faire?
    Par Lameth dans le forum APIs
    Réponses: 10
    Dernier message: 05/05/2008, 01h32
  3. [SQLLite] requete SQL comment faire
    Par babaahmed dans le forum Langage SQL
    Réponses: 8
    Dernier message: 02/06/2006, 17h09
  4. [struts requete sql] comment faire un wait
    Par chouchou93 dans le forum Struts 1
    Réponses: 1
    Dernier message: 15/05/2006, 19h04
  5. [SQL] requetes inbriquées, comment faire celle ci??
    Par Devil666 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 20/05/2005, 15h44

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