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 :

Requête jointure deux tables et affichage tableau des données. [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2010
    Messages : 8
    Points : 5
    Points
    5
    Par défaut Requête jointure deux tables et affichage tableau des données.
    Bonjour,

    Je rencontre un problème pour récupérer et afficher les données provenant d’une basse de données contenant les différentes notes des matières des élèves.

    La base de données, pour exemple, contient deux tables.

    La première table : utilisateurs. Cette table contient les noms (nom_util) et les prénoms (prenom_util) des élèves. Chaque élève possède un numéro unique (id_util) et est affecté à une classe (id_periode).

    La seconde table : note2015. Cette table contient la note (note_mat) et la matière (chrono_mat). Chaque matière possède son propre numéro. Cette note est associée à un élève (id_eleve). Dans ce champ (id_eleve), la valeur est la même que celle du champ (id_util) de la table utilisateurs. Ces deux éléments permettent de faire une jonction entre les deux tables.

    Récapitulatif :

    Table utilisateur : id_util, nom_util, prenom_util, id_periode.
    Table note2015 : id_eleve, note_mat, chrono_mat.
    Jonction entre les deux tables avec id_util et id_eleve.

    Je veux récupérer l’ensemble des notes de toutes les matières selon la classe et les afficher selon le principe suivant :
    Nom(1) , prenom(1), note de la matière 1, note de la matière 2, note de la matière3…
    Nom(2) , prenom(2), note de la matière 1, note de la matière 2, note de la matière3…
    Ainsi de suite.

    Le choix de la classe se fait avec un formulaire ($_POST) qui permet de cibler la table à utiliser : note2015. Exemple : Si id_periode =3 alors utilise la table note2015.

    J’arrive à récupérer et à afficher le nom et le prénom de l’élève ainsi que la note associé d’une matière :
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $result=mysql_query (‘SELECT utilisateurs.nom_util, utilisateurs.prenom_util, note2015.note_mat FROM utilisateurs INNER JOIN note2015 ON id_eleve= utilisateurs.id_util WHERE chrono_mat=1). 
    While($ligne = mysql_fetch_array($result))
    {
    Puis les echo….
    }
    Dans cet exemple chrono_mat est égal à 1. Je peux remplacer la valeur par un $_POST[‘choix’] d’un formulaire.

    Si cette méthode fonctionne pour une matière je n’arrive pas à trouver la bonne requête pour toutes les matières et afficher les résultats
    Pouvez-vous m’aider SVP.

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Ton problème c'est l'affichage ou la récupération exactement ?
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2010
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    Bonjour,
    Les trois... en fait écrire la requête (dans une boucle ?), la récupération et l'affichage.

  4. #4
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 032
    Points
    34 032
    Billets dans le blog
    14
    Par défaut
    Voici la requête qui va vous donner les notes de tous les élèves dans toutes les matières :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT u.nom_util, u.prenom_util,
    	n.chrono_mat, n.note_mat
    FROM utilisateurs u
    LEFT OUTER JOIN note2015 n ON n.id_eleve = u.id_util
    ORDER BY u.nom_util, u.prenom_util,n.chrono_mat

    Ensuite, vous traitez l'affichage souhaité en utilisant le résultat de la requête.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2010
    Messages
    8
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2010
    Messages : 8
    Points : 5
    Points
    5
    Par défaut
    Bonjour,
    Merci à CinePhil, c'est bien la bonne requête Le problème est résolu.

  6. #6
    Nouveau Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2017
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2017
    Messages : 1
    Points : 1
    Points
    1
    Par défaut
    salut
    svp j'ai 2 tables sql eleve(num,nom) et classe(id)
    je veux remplir un tableau t tel que ses 2 premières colonnes contient num et nom , et sa 3 eme colonne contient id
    comment faire??!!!!!!!

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

Discussions similaires

  1. [AC-2003] Requête entre 2 tables multicritères : affichage "en dur" des noms des critères
    Par caesar23 dans le forum Requêtes et SQL.
    Réponses: 0
    Dernier message: 03/06/2010, 11h07
  2. Réponses: 3
    Dernier message: 02/07/2009, 15h13
  3. Requête sur deux tables en même temps
    Par will89 dans le forum Requêtes
    Réponses: 2
    Dernier message: 20/04/2006, 11h01
  4. Quelle requête liera deux tables en analysant leur contenu ?
    Par Monbasinstinct dans le forum Access
    Réponses: 14
    Dernier message: 13/04/2006, 18h03
  5. Problème de requêtes sur deux tables
    Par Pymm dans le forum Access
    Réponses: 6
    Dernier message: 06/09/2005, 09h06

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