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 :

Redondances dans les résultats d'une requête [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 55
    Points : 34
    Points
    34
    Par défaut Redondances dans les résultats d'une requête
    Bonjour à tous,

    J'ai besoin de votre aide car j'ai un problème de redondance des données extraites sur des tables que je n'arrive pas à résoudre avec SELECT DISTINCT ou GROUP BY. Ci-dessous le détail de mon projet :

    Ma BDD est composée de 4 tables qui sont :

    Table "installations" :

    id site
    1 site1
    2 site2
    3 site3

    Table "materieltypea" :

    MA_id MA_id_installations MA_nom
    1 1 matériel A 1
    2 2 matériel A 2
    3 3 matériel A 3

    Table "materieltypeb" :

    MB_id MB_id_installations MB_nom
    1 1 matériel B 1
    2 1 matériel B 2
    3 2 matériel B 3
    4 3 matériel B 4
    5 3 matériel B 5

    Table "materieltypec" :

    MC_id MC_id_installations MC_nom
    1 2 matériel C 1
    2 3 matériel C 2


    Je souhaite récupérer les données de ces 4 tables dans 2 listes dynamiques liées avec Ajax. La première liste affiche les données de la table "installations" et en fonction de l'installation sélectionnée, la deuxième liste affiche les données correspondantes dans les 3 autres tables. En suivant un tutoriel trouvé sur le net, j'ai rencontré 2 erreurs.
    Pour information, je ne peux pas regrouper les 3 tables matériels en 1 seule car ces tables ont chacune des caractéristiques propres et un nombre de colonnes différentes.

    Ci-dessous le détail du code :

    Code de la page "installations.php" :

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    <html>
    <head>
    	<title>Choix du matériel</title>
    	<script type='text/javascript'>
                    function getXhr(){
                        var xhr = null; 
                            if(window.XMLHttpRequest) // Firefox et autres
                               xhr = new XMLHttpRequest(); 
                            else if(window.ActiveXObject){ // Internet Explorer 
                               try {
                                    xhr = new ActiveXObject("Msxml2.XMLHTTP");
                                } catch (e) {
                                    xhr = new ActiveXObject("Microsoft.XMLHTTP");
                                }
                            }
                            else { // XMLHttpRequest non supporté par le navigateur 
                               alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest..."); 
                               xhr = false; 
                            } 
                                   return xhr;
                    }
                    /**
                    * Méthode qui sera appelée sur le click du bouton
                    */
                    function go(){
                            var xhr = getXhr();
                            // On défini ce qu'on va faire quand on aura la réponse
                            xhr.onreadystatechange = function(){
                                    // On ne fait quelque chose que si on a tout reçu et que le serveur est ok
                                    if(xhr.readyState == 4 && xhr.status == 200){
                                            leselect = xhr.responseText;
                                            // On se sert de innerHTML pour rajouter les options a la liste
                                            document.getElementById('materiels').innerHTML = leselect;
                                    }
                            }
                            // Ici on va voir comment faire du post
                            xhr.open("POST","ajaxMateriels.php",true);
                            // ne pas oublier ça pour le post
                            xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
                            // ne pas oublier de poster les arguments
                            // ici, l'id de l'auteur
                            sel = document.getElementById('installations');
                            idinstallations = sel.options[sel.selectedIndex].value;
                            xhr.send("idInstallations="+idinstallations);
                    }
            </script>
    </head>
    <body>
    	<form>
    		<fieldset style="width: 500px">
    			<legend>Liste liées</legend>
    			<label>Installations</label>
    			<select name='installations' id='installations' onchange='go()'>
    				<option value='-1'>Aucun</option>
    				<?php
                                            mysql_connect("localhost","root","root");
                                            mysql_select_db("test");
                                            $res = mysql_query("SELECT * FROM installations");
                                            while($row = mysql_fetch_assoc($res)){
                                                    echo "<option value='".$row["id"]."'>".$row["site"]."</option>";
                                            }
                                    ?>
    			</select>
    			<label>Matériels</label>
    			<div id='materiels' style='display:inline'>
    			<select name='materiels'>
    				<option value='-1'>Choisir un site</option>
    			</select>
    			</div>
    		</fieldset>
    	</form>
    </body>
    </html>

    Code de la page "ajaxMateriels.php" :

    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Document sans titre</title>
    </head>
     
    <body>
     
    <?php
    	echo "<select name='materiels'>";
    	if(isset($_POST["idInstallations"])){
    		mysql_connect("localhost","root","root");
    		mysql_select_db("test");
    		$res = mysql_query("SELECT * FROM materieltypea, materieltypeb, materieltypec WHERE MA_id_installations=".$_POST["idInstallations"]." AND MB_id_installations=".$_POST["idInstallations"]." AND MC_id_installations=".$_POST["idInstallations"]."");
    		while($row = mysql_fetch_assoc($res)){
    			echo "<option value='".$row["MA_id"]."'>".$row["MA_nom"]."</option>";
    			echo "<option value='".$row["MB_id"]."'>".$row["MB_nom"]."</option>";
    			echo "<option value='".$row["MC_id"]."'>".$row["MC_nom"]."</option>";
    		}
    	}
    	echo "</select>";
    ?>
    </body>
    </html>



    La liste "installations" fonctionne correctement et tous mes sites sont listés. Par contre, j'obtiens les résultats suivants sur la deuxième liste :

    • Si je sélectionne "site 1", je n'ai aucun résultat qui s'affiche. Vu que j'appelle la table "materieltypec" et qu'il n'y a pas de liaison pour ce matériel avec le site1, ça doit me générer une erreur...


    • Si je sélectionne "site 2", les résultats obtenus sont :
    - Matériel A 2
    - Matériel B 3
    - Matériel C 1
    ==> pas de soucis

    • Si je sélectionne "site 3", les résultats obtenus sont :
    - Matériel A 3
    - Matériel B 4
    - Matériel C 2
    - Matériel A 3
    - Matériel B 5
    - Matériel C 2
    ==> redondances

    Je souhaiterais que les résultats soient :

    Site 1 :
    - Matériel A 1
    - Matériel B 1
    - Matériel B 2

    Site 2 :
    - Matériel A 2
    - Matériel B 3
    - Matériel C 1

    Site 3 :
    - Matériel A 3
    - Matériel B 4
    - Matériel B 5
    - Matériel C 2




    Merci d'avance pour votre aide à un débutant dans le domaine
    Bonne soirée

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Tu utilises le script JavaScript d'un tutoriel AJAX.
    Où as-tu vu dans ce tutoriel qu'une page appelée en AJAX doit retourner une page HTML complète ?
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 55
    Points : 34
    Points
    34
    Par défaut
    J'ai collé le code PHP dans une page PHP dreamweaver et par défaut il met ce code, je ne l'ai pas enlevé. Ta remarque concerne bien le fichier ajaxMateriel ? Il faut juste mettre le code ci-dessous ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <?php
    	echo "<select name='materiels'>";
    	if(isset($_POST["idInstallations"])){
    		mysql_connect("localhost","root","root");
    		mysql_select_db("test");
    		$res = mysql_query("SELECT * FROM materieltypea, materieltypeb, materieltypec WHERE MA_id_installations=".$_POST["idInstallations"]." AND MB_id_installations=".$_POST["idInstallations"]." AND MC_id_installations=".$_POST["idInstallations"]."");
    		while($row = mysql_fetch_assoc($res)){
    			echo "<option value='".$row["MA_id"]."'>".$row["MA_nom"]."</option>";
    			echo "<option value='".$row["MB_id"]."'>".$row["MB_nom"]."</option>";
    			echo "<option value='".$row["MC_id"]."'>".$row["MC_nom"]."</option>";
    		}
    	}
    	echo "</select>";
    ?>

    Comme indiqué, dans le précédent message, ce code est tiré d'un tutoriel disponible à cette adresse : http://siddh.developpez.com/articles/ajax/

  4. #4
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Pour ton problème de redondance, il faut utiliser un DISTINCT à priori.

    Sinon, l'extension mysql_* est dépréciée et sera prochainement supprimée de PHP, tu devrais passer à mysqli_* ou PDO.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 55
    Points : 34
    Points
    34
    Par défaut
    Salut,

    Merci pour ta réponse mais comme indiqué, DISTINCT et GROUP BY ne permettent pas de sortir les données voulues. Je pensais qu'une petit modification dans mes requêtes aurait résolu mon problème mais apparemment c'est plus complexe que ça.

    Actuellement mon site fonctionne donc tant pis si je n'arrive pas à réaliser ces listes déroulantes. C'était juste pour rendre plus agréable et plus simple la navigation grâce à des menus déroulants liés.

    Merci quand même pour tes compléments.
    A+

  6. #6
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    Essaie cela, je ne suis pas bien sûre d'avoir saisi ta problématique.
    Mais si c'est ce qui suit, c'est surtout que tu aurais du te contenter d'une seule table avec un champ site en plus.
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    SELECT 
    MA_nom as nom
    FROM materieltypea
    WHERE MA_id_installations="3"
     
    UNION
     
    SELECT 
    MB_nom as nom
    FROM materieltypeb
    WHERE MB_id_installations="3"
     
    UNION
     
    SELECT 
    MC_nom as nom
    FROM materieltypec
    WHERE MC_id_installations="3"
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 55
    Points : 34
    Points
    34
    Par défaut
    Bonjour Dentrite,

    Merci beaucoup pour ta réponse, j'ai effectivement pu résoudre mon problème à l'aide la commande "UNION" qui m'a permis d'assembler mes tables.

    Encore merci aux différentes réponses apportées à ma demande.

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

Discussions similaires

  1. [AC-2007] Comment naviguer dans les résultats d'une requête ?
    Par DurDur dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 02/05/2015, 13h27
  2. Réponses: 2
    Dernier message: 23/01/2008, 08h36
  3. [MySQL] Passer les résultats d'une requête dans un tableau 2D pour un webservice ?
    Par tintin72 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 24/06/2007, 01h36
  4. Réponses: 5
    Dernier message: 20/03/2007, 17h55
  5. Transformer les résultats d'une requête dans un autre ordre
    Par keikun dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 12/04/2006, 16h29

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