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

Langage PHP Discussion :

Filtre sur données


Sujet :

Langage PHP

  1. #1
    Membre habitué
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 365
    Points : 192
    Points
    192
    Par défaut Filtre sur données
    Bonjour,

    Au 1er affichage, le code suivant me permet de lister tous mes livres provenant d'une base de données Mysql. Sur cette liste globale, je peux dans un 2nd temps cliquer soit :

    - sur un lien "GENRE" qui me permet de filtrer les données en n'affichant que les livres de tel GENRE
    - sur un lien "ID_AUTEUR" qui me permet de filtrer les données en n'affichant que les livres de tel auteur

    Ces 2 possibilités fonctionnent :

    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
    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
     
    <?php
     
    // Connexion à la base de donnée
    require_once("connexionMysql.inc.php");
     
    // Le nom de la table
    $tablename = 'liste';
     
    $ID_AUTEUR = (iSset($_GET['ID_AUTEUR']) ? $_GET['ID_AUTEUR'] : null);
    $GENRE = (iSset($_GET['GENRE']) ? $_GET['GENRE'] : null);
     
    // La requête
     
    $requete = "SELECT *
            FROM ".$tablename;
     
    if ( $ID_AUTEUR != null) { // on ajoute le critère que s'il est demandé
      $requete  .= " WHERE ID_AUTEUR=".$ID_AUTEUR; 
    }
    if ( $GENRE != null) { // on ajoute le critère que s'il est demandé
      $requete  .= " WHERE GENRE='".$GENRE."'"; 
    }
     
    $resultat = mysql_query($requete) or die('Erreur SQL !'.$requete.'<br>'.mysql_error());
     
     
    ?>
     
    <!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 nom</title>
    <link rel="stylesheet" type="text/css" href="styles/biblio.css" media="all" />
     
    </head>
     
    <body>
     
    <div id="global">
     
    	<div>
     
    <?php while($donnees=mysql_fetch_array($resultat))  { ?> 
     
    		<ul>
    			<li class="auteur"><a href="liste_livres.php?ID_AUTEUR=<?php echo $donnees['ID_AUTEUR']; ?>"><?php echo $donnees['AUTEUR']; ?></a></li>
    			<li class="genre"><a href="liste_livres.php?GENRE=<?php echo $donnees['GENRE']; ?>&ID_AUTEUR=<?php echo $ID_AUTEUR; ?>"class="lien2"><?php echo $donnees['GENRE']; ?></a></li>	
    		</ul>    
     
    	</div>
    	  <?php 
    	  } ?>
     
    </div>
    <!-- #global -->
     
    </body>
     
    </html>
    En revanche, ce qui ne fonctionne pas c'est l'association de ces 2 possibilités. A savoir, après avoir cliqué sur un lien "ID_AUTEUR" qui m'affiche la liste des livres de tel auteur, je voudrais pouvoir filtrer cette liste en n'affichant que les livres de cet auteur ayant tel thème (ce qui revient à faire 2 filtres en 2 temps). Mais j'ai l'erreur suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT * FROM liste WHERE ID_AUTEUR=31 WHERE GENRE='thriller'  Erreur SQL !SELECT * FROM liste WHERE ID_AUTEUR=31 WHERE GENRE='thriller' You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE GENRE='thriller' at line 2
    Je vois bien que WHERE apparaît 2 fois ce qui ne me semble pas normal...
    Pouvez-vous m'aider à parvenir au résultat escompté ? Merci.

  2. #2
    Modérateur
    Avatar de Vil'Coyote
    Homme Profil pro
    Développeur adélia & Web
    Inscrit en
    Février 2008
    Messages
    4 583
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur adélia & Web
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2008
    Messages : 4 583
    Points : 7 503
    Points
    7 503
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
     
    if ( $ID_AUTEUR != null) {
      $requete  .= " WHERE ID_AUTEUR='".$ID_AUTEUR."'";
     
      if ( $GENRE != null) { $requete  .= " and GENRE='".$GENRE."'"; }
     
    }
    else
    {
      if( $GENRE != null) { // on ajoute le critère que s'il est demandé
      $requete  .= " WHERE GENRE='".$GENRE."'"; 
      }
    }
    la vie n'est pas cirrhose des foies ...

    Avant de poster un message Rechercher n'est pas qu'une option.
    FAQ Web - Tuto Web

  3. #3
    Membre habitué
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 365
    Points : 192
    Points
    192
    Par défaut
    Merci pour la modification de mon code .Cela fonctionne conformément à mes attentes.

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

Discussions similaires

  1. [WebI Xi3] Filtre sur données vides et non vides dans la base
    Par gwena2b dans le forum Débuter
    Réponses: 1
    Dernier message: 04/02/2015, 13h51
  2. [9.1] Filtre sur donnée de type tableau de bigint
    Par jeanphi45 dans le forum PostgreSQL
    Réponses: 4
    Dernier message: 18/11/2013, 20h11
  3. [XL-2007] Filtre sur données issues de champs importés depuis tables Word
    Par Vitalic dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 21/02/2011, 09h33
  4. filtre sur donnée numérique
    Par Daranc dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 10/04/2007, 17h25
  5. Filtre sur les données des 3 derniers mois?
    Par Arkalys dans le forum Access
    Réponses: 2
    Dernier message: 21/10/2005, 09h02

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