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 :

PreparedStatement et liste


Sujet :

JDBC Java

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    167
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 167
    Par défaut PreparedStatement et liste
    Bonjour a tous.
    Je souhaiterez faire des requetes via jdbc mais de la forme
    select * from matable where id in (213,3213,321)
    Seulement je souhaite faire ceci de manière dynamique.

    Ainsi la requete que je passe au PreparedStatement :
    select * from matable where id in (?)
    Je souhaite donc fournir une liste d'identifiant au PreparedStatement, de manière a ce qu'il me fournisse plusieurs lignes de données.

    J'ai essayé de faire ceci avec un set String
    ps.setString(213,321)
    Mais il ne me prend pas mes deux id de manière indépendante, il prend un seul Id : 213,321...

    Comment peut on passer une liste de valeur définie dynamiquement à un PreparedStatement?
    Si cela n'est pas possible avec un PreparedStatement, existe t'il une manière simple pour faire cela?
    (Au pire, je n'utilise pas de PreparedStatement, et je génère la requete directement en chaine de caractère, mais je ne trouve pas cela très 'propre')

    Merci d'avance !

  2. #2
    in
    in est déconnecté
    Membre Expert Avatar de in
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 612
    Par défaut
    et bien

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ps.setString("213,321")
    tout simplement non ?

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    167
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 167
    Par défaut
    euh, non...c'est pas si simple, désolé j'ai fais une faute de frappe en expliquant mon problème.
    En fait, je passe au setString la valeur d'un JTextField, je suis donc bien en String...
    Ce que je fais en fait, c'est ca :

    ps.setString(1,"213,254");
    Mais merci quand même...

  4. #4
    in
    in est déconnecté
    Membre Expert Avatar de in
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 612
    Par défaut
    ben pourtant moi je le fait comme ça chez moi et je n'ai pas de problème ...

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    167
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 167
    Par défaut
    Pour compléter mon post :

    Voila la requete :
    select mega_id_rum,rrumno, rpat, rrss, rdate, rdats, rmode, rmods, ruf, mega_sigma, rtrim(ltrim(mega_dossier)) "Num dossier", rbloque
    from rum
    where mega_id_rum in (?)
    Et la méthode qui l'execute.

    public ResultSet getRumService(String id_rum){
    ResultSet rs = null;
    try{
    String requete = req.get_req("1");
    logger.log(Level.FINE,"Execution de "+requete);
    Connection con = this.connect("service@expdim_mega");

    PreparedStatement ps = con.prepareStatement(requete);
    ps.setString(1,"3000012,3000013");
    //ps.
    rs = ps.executeQuery();
    logger.log(Level.INFO,"Initialisation du resultSet réalisée");
    }
    catch(Exception e){
    System.out.println("Catch 1!!");
    e.printStackTrace();
    }
    return rs;
    }
    Quand je fais :
    ps.setString(1,"3000012");
    Ca fonctionne, de même quand je fais :
    ps.setString(1,"3000013");
    Par contre, quand je fais
    ps.setString(1,"3000012,3000013");
    Il ne me retourne aucune ligne (alors qu'elles existent...)
    Donc si vous avez une idée, je vous en serait très reconnaissant!

    J'ai vu sur le forum de sun que quelqu'un a essayé en utilisant un setArray ...seulement il rencontre aussi quelques problèmes...donc si quelqu'un a déjà utilisé cette méthode, je suis preneur d'un petite explication.

    Merci d'avance !

  6. #6
    Membre Expert
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    1 348
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 348
    Par défaut
    mega_id_rum ne serait pas une String en base ? Dans ce cas, ça serait normal que ça ne fonctionne pas, car en sql les String ont des séparateurs.
    Pour être plus clair, je mets les requêtes "générées" par jdbc dans les trois cas :
    Cas 1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ... where mega_id_rum in ('3000012')
    Cas 2
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ... where mega_id_rum in ('3000013')
    Cas 3
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ... where mega_id_rum in ('3000012,3000013')
    Ce que tu voudrais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ... where mega_id_rum in ('3000012','3000013')
    A mon sens le plus "propre" est de générer ton prepared statement avec une boucle, pour avoir
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ... where mega_id_rum in (?,?,?,?,?,?,?,?,?)

  7. #7
    in
    in est déconnecté
    Membre Expert Avatar de in
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 612
    Par défaut
    ha oui autant pour moi. effectivement je crée un String ayant cette forme "'aaa','bbb','ccc'" ... c'est pour ça que ça marche. Mais bon c'est un cas bien précis ou je sais qu'il n'y a pas de caractère spéciaux ....

  8. #8
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    167
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 167
    Par défaut
    Ben effectivement, c'est bien la mon problème...
    J'avoue avoir déjà pensé à la génération de chaine avec une boucle...mais bon, j'espère trouver un moyen plus direct...(par exemple avec un setArray ou autre).
    La génération de chaine fonctionne bien, seulement au niveau de l'architecture de mon programme ca ne m'arrange pas tellement...donc si vous avez d'autres techniques je suis preneur...sinon, je ferais la concat de chaine...
    Mais bon, je suis assez étonné qu'il aient pas prévu chez sun le cas des requetes "select in"...
    Ps, j'utilise une base Oracle 9i

    Ah oui, sinon, mon champ mega_id_rum est un number en bdd...(sachant que si on fais un setString sur un number simple, ca fonctionne très bien aussi...)

  9. #9
    Membre Expert
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    1 348
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 348
    Par défaut
    Oui oui c'est pas un problème le setString avec le number en base...
    En fait je pensais que le problème des séparateurs était lié au type en base, mais peut être pas (j'avais jamais essaye avec un number).

    Honnêtement, je suis 99% sûr qu'il n'y a pas de solution "propre" pour gérer "la valeur" d'un in avec un prepared ... Je suis totalement d'accord que la boucle c'est en général très moyen

  10. #10
    in
    in est déconnecté
    Membre Expert Avatar de in
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 612
    Par défaut
    bon j'ai pas vraiment lu, mais je suis tombé sur ça. A priori c'est avec Array qu'il faut faire. Je te laisse découvrir ...

    [EDIT] en même temps il est un peu pauvre l'exemple. J'espère que ça te servira quand même

  11. #11
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    167
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 167
    Par défaut
    Merci pour vos réponse...j'ai essayé pleins de choses...même avec un setArray...mais bon, j'ai pas réussi a faire ce que je voulais...
    Du coup j'utilise ceci :
    String in_param //que je rempli avec ma liste d'id, séparé par des virgules
    requete = requete.replaceAll("in \\(\\?\\)",in_param);
    Et voila, le tour est joué...mais bon, j'espérait cela plus propre...en tout cas merci de votre contribution!

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

Discussions similaires

  1. Passer une liste de string dans un preparedstatement
    Par thierryler dans le forum JDBC
    Réponses: 6
    Dernier message: 13/03/2008, 14h30
  2. PreparedStatement, setString et List
    Par babylone7 dans le forum JDBC
    Réponses: 4
    Dernier message: 29/09/2006, 09h35
  3. tri de liste chainée
    Par RezzA dans le forum C
    Réponses: 7
    Dernier message: 26/01/2003, 20h25
  4. Compter le nombre ligne listée (COUNT) ?
    Par StouffR dans le forum Langage SQL
    Réponses: 7
    Dernier message: 02/09/2002, 09h41
  5. Listes déroulantes liées entre elles
    Par denisC dans le forum Général JavaScript
    Réponses: 0
    Dernier message: 27/07/2002, 15h53

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