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

JDBC Java Discussion :

recherche sur plusieurs champs dans DB


Sujet :

JDBC Java

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2015
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Santé

    Informations forums :
    Inscription : Août 2015
    Messages : 12
    Par défaut recherche sur plusieurs champs dans DB
    bonjour,
    je suis étudiant en programmation et pour notre premier projet en java, je dois faire un petit soft de gestion de webshop en 2 partie:

    1 l'interface marchand en java
    2 l'interface client sera une web app en c#

    je souhaiterai utiliser des filtres pour rechercher et afficher mes produits dans ma db (sqlServer)

    ce genre d'interface:

    Nom : filtres.JPG
Affichages : 94
Taille : 27,9 Ko


    Est ce que je dois faire une fonction/méthode pour chaque nombre d'interface exemple:

    if (checkbox.checked.count = 1)
    Code fictif.. je vous rassure c’est juste pour m'expliquer
    fonctionRecherche1(param1) ---> select From Table where nomcol=param1

    if (checkbox.checked.count = 2)
    fonctionRecherche2(param1,param2); ---> select From Table where nomcol1=param1 AND nomcol2=param2

    Et ainsi de suite? fonctionRecherche3(param1,param2,param3)

    Dans mon cas je n'ai "que" 10-12 filtres possibles, mais si il y en a 150! il doit y avoir moyen de gérer ça de manière dynamique?

    Merci d'avance

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Billets dans le blog
    2
    Par défaut
    Salut,

    On peut créer la requête dynamiquement par concaténation :

    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
     
    StringBuilder sb = new StringBuilder("Select * from TABLE");
    boolean where=false;
    List<Object> values = new ArrayList<>();
     
    for(Parameter parameter : parameters) { // Parameter une classe perso fait à dessein
     
       if( parameter.isSet() ) {
     
            if ( where ) {
                 sb.append(" AND ");
            }
            else {
                 sb.append(" WHERE ");
                 where=true;
            }
     
           parameter.append(sb, values);
     
       }
     
    }
     
    PreparedStatement statement = cnx.prepareStatement(sb.toString());
    for(int i=0; i<values.size(); i++) {
         statement.setObject(i+1, values.get(i));
    }
    /*...*/
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2015
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Santé

    Informations forums :
    Inscription : Août 2015
    Messages : 12
    Par défaut
    Merci pour la réponse, c'est clair, net et précis. je n'en attendais pas tant...

Discussions similaires

  1. [AC-2003] Tri sur plusieurs champs dans zone de liste
    Par Orakle dans le forum IHM
    Réponses: 3
    Dernier message: 18/06/2009, 09h12
  2. Recherche sur plusieurs champs.
    Par icicmoi dans le forum JDBC
    Réponses: 6
    Dernier message: 09/08/2008, 00h54
  3. Réponses: 8
    Dernier message: 13/04/2008, 14h44
  4. [Débutant]Recherche sur plusieurs champs
    Par Touareg dans le forum Langage SQL
    Réponses: 2
    Dernier message: 21/03/2007, 14h04
  5. Réponses: 2
    Dernier message: 30/11/2004, 09h42

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