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 :

erreur requete pdo [PDO]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Avril 2013
    Messages : 139
    Par défaut erreur requete pdo
    Bonjour,
    J'aimerais afficher les membres connectés (avec a coté un carré vert) et les membres deconnecté , le tout dans une meme colonne et dans l'ordre..
    Mais je n'y parvient pas...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <?php
    $AfficherMembres = $pdo->prepare("SELECT login as loginc FROM connectes UNION Select login from utilisateur u where id NOT IN (SELECT id_utilisateur FROM connectes) order by login ");
    $AfficherMembres ->execute();
    ?>
    </div>
    <div class="panel-body">
    <?php
    while($Value=$AfficherMembres ->fetch()) {
    	$login=htmlspecialchars($Value['login']);
    	echo '<center><span class="vert" alt="en ligne">■</span>   <a href="viewprofil.php?login='.$login.'">'.$login."</a><br/></center>";
    }?>
    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
    Et quel est ton problème precisement ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    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 : 40
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Attention, dans une requête UNION, les champs des deux requêtes doivent avoir les mêmes noms. Si tu veux différencier de quelle requête viennent les résultats, je te conseille d'ajouter un 2e champ avec une valeur fixe :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    (
        SELECT login, '1' as connecte
        FROM connectes 
    )
    UNION 
    (
        Select login, '0' as connecte 
        from utilisateur u 
        where id NOT IN (SELECT id_utilisateur FROM connectes) 
    )
    order by login
    Tu as juste à tester la valeur de ton 2e champ pour afficher ou non ton carré vert
    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]

  4. #4
    Membre confirmé
    Homme Profil pro
    Etudiant CNAM (DIE20)
    Inscrit en
    Janvier 2010
    Messages
    151
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant CNAM (DIE20)

    Informations forums :
    Inscription : Janvier 2010
    Messages : 151
    Par défaut
    Je te propose cette solution qui me parait beaucoup plus simple (1 seul SELECT contre 3 dans ta méthode) :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT
    	u.login,
    	c.login = u.login AS is_connected
    FROM
    	utilisateur u
    	LEFT OUTER JOIN connecte c ON c.login = u.login
    ORDER BY u.login;

    Explication :
    - jointure externe gauche entre les tables "utilisateur" et "connecte" : si l'utilisateur est connecté, le login apparait, sinon c.login est NULL. Dans tous les cas, tous les login présents dans "utilisateur" sont renvoyés.
    - "is_connected" est un BOOLEAN qui renvoie TRUE si connecté (login trouvé dans les 2 tables), FALSE sinon (car dans ce cas c.login est NULL).

    à tester sur sqlfiddle.com (syntaxe postgreSQL)

  5. #5
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Avril 2013
    Messages
    139
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Avril 2013
    Messages : 139
    Par défaut
    Merci

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

Discussions similaires

  1. Requete Pdo multiple valeurs et retour d'erreurs.
    Par SAmpistaroy dans le forum Débuter
    Réponses: 2
    Dernier message: 24/12/2012, 01h25
  2. Erreur requete SQL/Access
    Par polianita dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 08/06/2006, 15h20
  3. Erreur requete en VBA
    Par temar dans le forum Access
    Réponses: 15
    Dernier message: 19/05/2006, 19h50
  4. Erreur requete MySQL
    Par kanabzh29 dans le forum Requêtes
    Réponses: 7
    Dernier message: 05/05/2006, 14h08
  5. [debutante] erreur requete update
    Par LineLe dans le forum ASP
    Réponses: 5
    Dernier message: 12/09/2003, 13h05

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