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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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 (?,?,?,?,?,?,?,?,?)

+ 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, 15h30
  2. PreparedStatement, setString et List
    Par babylone7 dans le forum JDBC
    Réponses: 4
    Dernier message: 29/09/2006, 10h35
  3. tri de liste chainée
    Par RezzA dans le forum C
    Réponses: 7
    Dernier message: 26/01/2003, 21h25
  4. Compter le nombre ligne listée (COUNT) ?
    Par StouffR dans le forum Langage SQL
    Réponses: 7
    Dernier message: 02/09/2002, 10h41
  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, 16h53

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