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 :

[SQL] Utilisation de distinct


Sujet :

PHP & Base de données

  1. #21
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 292
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $sql_head="SELECT DISTINCT Headliner FROM active_headliners WHERE HeadlinerID=$headlinerId";
    echo "$sql_head <br>";
    
    $result_head= mysql_query($sql_head) OR die(mysql_error());
    while($row_head=mysql_fetch_array($result_head))
    {	
    // $row_head['HeadlinerID'] ne peut rien donner, puisque HeadlinerID n'est pas dans ta requête 
      $headliner=$row_head['Headliner'];
    // tu n'utilises nulle part ce résultat !
      echo "<P>Headliner de l'ID $headlinerId : $headliner</P>" ;
    }

  2. #22
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Par défaut
    Citation Envoyé par Antoun
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $sql_head="SELECT DISTINCT Headliner FROM active_headliners WHERE HeadlinerID=$headlinerId";
    echo "$sql_head <br>";
    
    $result_head= mysql_query($sql_head) OR die(mysql_error());
    while($row_head=mysql_fetch_array($result_head))
    {	
    // $row_head['HeadlinerID'] ne peut rien donner, puisque HeadlinerID n'est pas dans ta requête 
      $headliner=$row_head['Headliner'];
    // tu n'utilises nulle part ce résultat !
      echo "<P>Headliner de l'ID $headlinerId : $headliner</P>" ;
    }

    merci pour ta réponse, j'ai pas fais attention au fait que je ne selectionne pas le HeadlinerID...
    et pour le Headliner je l'utilise après... je l'ajoute dans une liste déroulante...
    comment puis selectionner le distinct et d'autres elements en utilisant une seule requete??

    merci encore

  3. #23
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 292
    Par défaut
    Citation Envoyé par toddy_101
    merci pour ta réponse, j'ai pas fais attention au fait que je ne selectionne pas le HeadlinerID...
    et pour le Headliner je l'utilise après...
    Donc quand tes boucles ont tourné...
    Citation Envoyé par toddy_101
    je l'ajoute dans une liste déroulante...
    comment puis selectionner le distinct et d'autres elements en utilisant une seule requete??
    ce que tu veux n'est pas très clair... peux-tu me montrer le résultat que tu souhaites, et je te dirai comment l'obtenir (si c'est possible) ?

  4. #24
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Par défaut
    Salut Antoun,

    désolé j'ai beaucoup tardé, mais j'étais en vacances... et la mauvaise nouvelle est que j'ai toujours le meme probleme!!

    je fais un distint sur un champ et ca me retourne le meme elements plusieurs fois...

    est ce que c'est possible de faire ca:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT DISTINCT Headliner, HeadlinerID 
    FROM  active_headliners 
    WHERE HeadlinerID=$headlinerId
    avec cette requete j'ai toujours le meme resultat!! le Headliner est affiché plusieurs fois

    Merci encore

  5. #25
    Membre éprouvé
    Avatar de Rakken
    Homme Profil pro
    Inscrit en
    Août 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 257
    Par défaut
    Avec ta requete, tu affiches toutes les "lignes" distinctent. En d'autre termes, tous les couples "Headliner" + "HeadlinerID" distinct.
    Donc, si pour chaque Headliner tu as plusieurs HeadlinerID, tu verras plusieurs fois le Headliner.

    --
    Rakken

  6. #26
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Par défaut
    ah oui... je vois ce que tu veux dire. tu as raison!
    tu as une idée pour éviter ca? pour ke j'aille seulement une seule fois affiché le headliner?

    merci

  7. #27
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 292
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 292
    Par défaut
    Pour afficher le headliner seulement, c'est ta requête initiale :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT DISTINCT Headliner
    FROM  active_headliners 
    WHERE HeadlinerID=$headlinerId
    Pour afficher chaque headliner et l'ensemble des ID qui ont le même headliner, tu peux utiliser ça (avec MySQL seulement) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT Headliner, 
      COUNT(*) AS Nb_ID,
      GROUP_CONCAT(HeadlinerID) AS ListeID
    FROM  active_headliners 
    GROUP BY Headliner
    Mais ton problème n'est pas du tout tes requêtes SQL, c'est ton code PHP qui est construit sur une mauvaise architecture (faire des boucle imbriquées avec des petites requêtes, au lieu d'une seule boucle/requête avec des jointures) et qui ne t'affiche pas les bonnes infos à l'intérieur.

  8. #28
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Par défaut
    salut,

    j'ai essayé ta requete mais ca ne marche pas...

    You have an error in your SQL syntax near '(HeadlinerID) AS ListeID FROM active_headliners GROUP BY Headliner' at line 3

    la version de mysql est recente: 4.1.7

  9. #29
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Par défaut
    Re,

    je veux seulement savoir comment obtenir un resultat avec un champ non répété en utilisant la clause WHERE.

    peut etre j'aurai besoin d'utiliser des requetes imbriquées???

  10. #30
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Par défaut
    BiNGO!!!

    j'ai suivi les conseils de Monsieur Antoun et apparement il avait raison!!

    j'ai changé l'architecture et ca a marché! je ne sais pas ce qui m'est arrivé pour utiliser toutes ces boucles

    voici la requete qui marche:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
     
    SELECT DISTINCT  a.Headliner, a.HeadlinerID
    FROM  venue_list_active v, list_active l, active_headliners a
    WHERE v.city='$city' AND v.VenueID=l.VenueID AND  a.HeadlinerID=l.HeadlinerID
    Encore Merci

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Réponses: 3
    Dernier message: 07/05/2007, 20h57
  2. [forms]quel declencheur pl/sql utiliser?
    Par popov2 dans le forum PL/SQL
    Réponses: 3
    Dernier message: 30/08/2005, 12h19
  3. [SQL]emploie de DISTINCT
    Par fabszn dans le forum Langage SQL
    Réponses: 7
    Dernier message: 21/06/2005, 21h07
  4. Pl/SQL utilisation d'une variable dans un select
    Par larg dans le forum PL/SQL
    Réponses: 17
    Dernier message: 30/11/2004, 18h08
  5. [PL/SQL] Utilisation table PL/SQL dans clause IN
    Par Yorglaa dans le forum PL/SQL
    Réponses: 13
    Dernier message: 05/10/2004, 11h36

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