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 :

WHERE MYSQL et if php [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 15
    Par défaut WHERE MYSQL et if php
    bonjour, voila je voudrais faire un affichage d'une requette sql avec condition where (3 condition plus exactement)

    je voudrai que l'utilisateur choisisse dans 3 liste defillante ses option et quand il clique sur rechercher il puisse voir le resultat

    mais n'étant pas sur qu'il choississe toutes les option du formulare je voudrai savoir si dans la requet il est possible de faire une condition du sype

    si $a n'est pas vide

    req = select * from table where a=$a

    else

    req = SELECT * FROM table ;

    ayant 3 choix je vois le nombre de combinaison important et le nombre de if et elseif a faire

    je voudrais savoir s'il y aurais un moyen plus rapide de retourner au meme resultat

    merci d'avance

  2. #2
    Inactif
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    179
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 179
    Par défaut
    Un truc du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    $form_data_keys = array('a', 'b', 'r', 'w');
    $conditions = array();
    foreach ($form_data_keys as $key) {
      if (isset($_POST[$key])) {
        $conditions[] = $key . ' = ?';
      }
    }
    $query = 'SELECT ... WHERE ' . implode(' AND ', $conditions);
    Après tu reboucles sur les keys pour faire les binds des paramètres.

    J'ai supposé ici que tu utilisais mysqli ou une solution te permettant de faire des prepared statements, ce qui est toujours fortement recommandé.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 15
    Par défaut
    oui tu as bien supposer c vrai que j'ai oublier de dire que c'était une base de donner mysql ^^

    je comprend ton code ^^ mais en revanche je me demande si je met par exemple b indefini est<ce que ca va poser un problele a la requete ou est ce qu'il va juste le zapper et passer au autre ne faisant l'affichage qu'avec les conditions defini ?

    en tout cas merci pour ta rapiditer

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 15
    Par défaut
    voila merci pour ton code, j'ai essayer de le placer mais je n'y arrive pas très bien, est<ce que quelqu'un pourrais m'expliquer comment mettre mes variables comme conditions

    merci d'avance

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

Discussions similaires

  1. est-il possible d'utiliser Mysql et du php sur un cd-rom??
    Par swan dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 01/05/2011, 16h23
  2. importer base mysql et script php...
    Par kenken38 dans le forum Administration
    Réponses: 8
    Dernier message: 04/05/2006, 17h03
  3. équivalent fonction mysql C en php
    Par splouf dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 22/01/2006, 19h41
  4. équivalent fonction mysql C en php
    Par splouf dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 13/01/2006, 14h23

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