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

MS SQL Server Discussion :

requete concatené selon les champ sont renseignés ou pas


Sujet :

MS SQL Server

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 63
    Points : 39
    Points
    39
    Par défaut requete concatené selon les champ sont renseignés ou pas
    voila mon probleme j'ai besoin de former un SELECT avec des condition
    c'est un formulaire ou il faut rentrer des criteres qui ne sont pas tous obligatoire
    donc il me faudrai un select du genre
    (si que le champ 1 est renseigné)
    Select * from table where nom="champ1"
    (si le champ 2 est renseigneé)
    Select * from table where nom="champ1" AND prenom="champs2"
    etc...
    voila je sais pas si je me suis bien fais comprendre mais si vous pouviez m'aider ce serai super sympa
    merci d'avance

  2. #2
    Membre du Club
    Inscrit en
    Janvier 2006
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 47
    Points : 56
    Points
    56
    Par défaut
    bonjour

    si j'ai bien compris vs voulez faire recuperer que les champ 1 et champ 2 qui sont renseignés ?

    j'attend confirmation pour vs proposer une reponse

    merci

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 63
    Points : 39
    Points
    39
    Par défaut merci de m'aider
    ba oui en fait j'ai en tout 5 champs comme je disai qui ne sont obligé d'etre renseigner donc a chaque fois si un champ est renseigner je veux le mettre dans le WHERE comme pour affiner la recherche quoi ...

  4. #4
    Invité
    Invité(e)
    Par défaut
    Et bien tu peux faire une variable $where que tu mets au départ à "where ".
    Puis à chaque fois que t'as un des chamsp remplis, tu fais : $where .= "monChamp='".valeurMonChamp."' ";

    Et tu peux mettre un compteur pour savoir si au moins un champs a été rempli. COmme ça, si t'as un premier champs rempli, compteur = 1, dans un autre champ, si compteur vaut 1 alors tu met un AND dans ta variable $where avant de mettre la condition, sinon tu met juste ta confition, et ainsi de suite.

    Et à la fin dans ta requête tu met "select * from table ".$where Et normalement ça devrait marcher

    (Je sais pas quel language tu utilises pour le faire, là c'était du PHP pour les variables, mais ça reste pareil je pense )

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 63
    Points : 39
    Points
    39
    Par défaut
    jvai essayer

  6. #6
    Expert confirmé
    Avatar de rudib
    Homme Profil pro
    Fakir SQL Server & NoSQL
    Inscrit en
    Mai 2006
    Messages
    2 573
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Fakir SQL Server & NoSQL

    Informations forums :
    Inscription : Mai 2006
    Messages : 2 573
    Points : 4 043
    Points
    4 043
    Par défaut
    Bonjour,

    Autre solution qui peut poser des problèmes de performances :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Select * from table where (nom=@nom OR @nom IS NULL) AND prenom=@prenom OR @prenom IS NULL)
    Valable avec passage de paramètres.
    S'il y a beaucoup de colonnes, il vaut mieux faire du SQL dynamique pour générer un plan d'exécution propre.

Discussions similaires

  1. [Oracle] Comment utiliser la requête update et modifier les données si les champs sont modifiés
    Par roswina dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 01/06/2015, 10h01
  2. Probleme de requete pour remplir les champs d'une table
    Par Jim_Nastiq dans le forum Langage SQL
    Réponses: 7
    Dernier message: 06/04/2006, 14h56
  3. [MySQL] verifier si les champs sont correct et les comparer a la bdd
    Par pod1978 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 31/03/2006, 13h36
  4. [Requete action]selon les critères de 2 champs, en modifié 1
    Par Nicko29 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 18/11/2005, 16h53
  5. fusionner 2 tables dont les champs sont identiques mais.....
    Par NoobX dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 27/10/2005, 16h12

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