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 :

Sélectionner tous les champs [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Octobre 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Octobre 2012
    Messages : 10
    Points : 8
    Points
    8
    Par défaut Sélectionner tous les champs
    Bonjour à tous

    Je suis en train de programmer un formulaire de recherche détaillée avec plusieurs critères sélectionnables

    Exemple:
    choisissez votre pays: Indifférent - France - Suisse - Belgique - etc...

    si l'utilisateur choisi un pays c'est très simple je fais select * from membres where pays='$idpays'.
    Par contre si l'utilisateur choisi indifférent je souhaiterais faire quelque chose du genre select * from membres where pays='ALL'.
    Comment fait-on pour faire ça?

    P-S: La solution de faire juste select * from membres n'est pas ce que je souhaiterais car ça m'obligerais à faire des conditions pour construire ma requête

    Merci d'avance pour vos réponses

  2. #2
    Membre expert
    Avatar de Spartacusply
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 1 723
    Points : 3 274
    Points
    3 274
    Par défaut
    P-S: La solution de faire juste "select * from membres" n'est pas ce que je souhaiterais car ça m'obligerais à faire des conditions pour construire ma requête
    Tu ne vas pourtant pas y échapper.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $conditions = "";
    if ($idpays != 'ALL') {
        $conditions = "where pays='$idpays'";
    }
    $query = "SELECT * FROM membres $conditions";
    Un message utile vous a aidé ? N'oubliez pas le

    www.simplifions.fr - Simplifier vos comptes entre amis !

  3. #3
    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
    Citation Envoyé par accentcom
    P-S: La solution de faire juste "select * from membres" n'est pas ce que je souhaiterais car ça m'obligerais à faire des conditions pour construire ma requête
    En quoi "faire des conditions" est-il gênant ?
    C'est quand même la base de toute programmation un tant soit peu évoluée...
    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

  4. #4
    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 : 39
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Pour renchérir sur mes estimés collègues, je ne vois surtout pas le rapport entre le fait de faire SELECT * from membres et le fait de faire des conditions.
    La partie SELECT détermine les champs que tu veux récupérer et les conditions déterminent dans quelles lignes de la table tu les récupères.
    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]

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Octobre 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Octobre 2012
    Messages : 10
    Points : 8
    Points
    8
    Par défaut
    Merci à tous pour vos réponses

    En fait je me suis peut-être mal exprimé.

    Bovino une programmation évoluée ne signifie pas de uniquement de faire des conditions mais aussi d'essayer de simplifier au maximum son code pour le faire évoluer plus facilement dans le futur

    Partons sur le fait que l'on fasse une recherche détaillée d'un appartement par exemple, le client peut sélectionner la localisation, surface, nombre de pieces, prix etc... de l'appartement
    Pour chacun de ces critères il peut sélectionner une valeur ou "indifférent"

    Ce que je cherche à savoir c'est est-ce qu'il existe un moyen d'éviter ça:
    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
    $condition="select * from appartements where ";
    if($localisation="indifferent"){
       $condition=$condition;
    }else{
       $condition=$condition." idlocalisation='$localisation'";
    }
    if($surface="indifferent"){
       $condition=$condition;
    }else{
       $condition=$condition." surface='$surface'";
    }
    if($prix="indifferent"){
       $condition=$condition;
    }else{
       $condition=$condition." prix='$prix'";
    }
    etc....
    (la syntaxe n'est pas tout à fait juste mais c'est pour montrer l'esprit)

    Est-il possible de simplifier les choses encore + que ça?

  6. #6
    Membre expert
    Avatar de Spartacusply
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 1 723
    Points : 3 274
    Points
    3 274
    Par défaut
    Ta syntaxe est même fausse, car si tu laisses le prix à indifférent, cela supprime toutes tes conditions.

    Voilà un exemple de comment tu pourrais faire assez simplement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $query = "SELECT * FROM membres WHERE 1 = 1";
    $condition = '';
    if ($localisation != "indifferent") {
        $condition .= " AND idlocalisation='$localisation'";
    }
    if ($surface != "indifferent") {
        $condition .= " AND surface='$surface'";
    }
    if ($prix != "indifferent") {
        $condition .= " AND prix='$prix'";
    }
    $query .= $condition;
    Un message utile vous a aidé ? N'oubliez pas le

    www.simplifions.fr - Simplifier vos comptes entre amis !

  7. #7
    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
    Citation Envoyé par accentcom
    une programmation évoluée ne signifie pas de uniquement de faire des conditions
    En même temps, ça n'a rien à voir avec ce que j'ai dit.
    J'ai dit que les conditions sont la base, pas l'alpha et l'omega.
    La base d'une maison, ce sont les fondations, mais les fondations ne constituent pas la maison...

    Ceci étant dit.
    Dans ton cas, le plus adapté selon moi de prime abord, ce serait de ne transmettre que les champs qui doivent être filtrés, ainsi, tu peux boucler sur ces champs pour créer tes différentes conditions.
    Un exemple basique servant uniquement à montrer le processus (mais à ne pas utiliser tel quel) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $conditions = array();
    foreach($_POST as $champ=>$valeur){
        $conditions[] = "$champ=$valeur";
    }
    $requete = "SELECT * FROM membres";
    if($conditions){
        $requete .= "WHERE " . implode(" AND ", $conditions);
    }
    Il y a des conditions et c'est réutilisable et adaptable.
    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

  8. #8
    Expert éminent sénior
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Points : 16 545
    Points
    16 545
    Billets dans le blog
    12
    Par défaut
    Salut,

    une autre manière de faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $sql  = 'SELECT * FROM membres';
    $data = [
        'localisation' => 'indifferent',
        'surface' => '20',
        'prix' => '1000'
    ];
    // on ne conserve que les valeurs à filtrer : <> 'indifferent'
    $data  = array_diff($data, ['indifferent']);
    $where = [];
    array_walk($data, function($v, $k) use (&$where) { $where[] = $k.'='.$v; });
    $sql  .= (empty($where)) ? '' : ' WHERE '.implode(' AND ', $where);

  9. #9
    Futur Membre du Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Octobre 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Octobre 2012
    Messages : 10
    Points : 8
    Points
    8
    Par défaut
    Merci à tous pour vos lumières
    Vos différentes réponses vont me permettre de faire ce que je souhaite.

    Bonne soirée et encore merci

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

Discussions similaires

  1. Sélectionner tous les champs sauf 1 ?
    Par beegees dans le forum Langage SQL
    Réponses: 3
    Dernier message: 03/11/2008, 11h44
  2. Réponses: 1
    Dernier message: 16/09/2007, 17h28
  3. Comment sélectionner tous les champs sauf quelques uns?
    Par bankette dans le forum Langage SQL
    Réponses: 5
    Dernier message: 14/06/2007, 02h40
  4. comment sélectionner tous les champ sauf quelques uns
    Par r0d dans le forum Langage SQL
    Réponses: 4
    Dernier message: 25/11/2006, 09h34
  5. Réponses: 1
    Dernier message: 08/02/2006, 17h17

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