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, setString et List


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
    Juillet 2003
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 214
    Par défaut PreparedStatement, setString et List
    Bonjour

    Voila je voudrais faire une requete du type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from produit where id_produit in (1,2,3,4,5,6)
    où (1,2,3,4,5,6) est une liste java :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    List codesProduits = new ArrayList();
    ...
    // traitement pour remplir la liste
    ...
    PreparedStatement pstmt = null;
    pstmt = connection.prepareStatement("select * from produit where id_produit in (?)");
    pstmt.setString(1,codesProduits.toString());
    Le pb en faisant ça c'est que ça insère de guillemets (normal, c'est une String) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from produit where id_produit in ('1,2,3,4,5,6')
    Donc je voulais savoir comment faire un truc du genre "pstmt.setList" ..

    Quelqu'un aurait-il déja eu ce cas ?

    Merci

    Florence

  2. #2
    Membre éprouvé Avatar de BainE
    Inscrit en
    Mai 2004
    Messages
    1 327
    Détails du profil
    Informations forums :
    Inscription : Mai 2004
    Messages : 1 327
    Par défaut
    je suis en train de faire un truc du genre, pour l'instant je genere un string avec autant de "?" que d'element dans ma liste.
    Pis tant que j'ai des elements

    statment.setString( pos, list.get( pos++ ) );

    c'est pas super je trouve, mais j'ai rien vu de mieux.
    A voir il existe peut etre une lib qui te permet de faire ca

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 214
    Par défaut
    Merci BainE, en effet c'est une idée mais j'ai des listes qui atteignent + de 500 enregistrements, alros niveau perf je ne sais pas ce que ça peut donner... ?
    Sinon, j'avais penser concatener la requete et la liste de cette manière :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    String req = "select * from produit where id_produit in ?"
     
    List codesProduits = new ArrayList();
    codesProduits.toString().replace('[',' ');
    codesProduits.toString().replace(']',' ');
     
    req += codesProduits.toString();
    Qu'en pensez vous ?

    Merci

  4. #4
    Membre chevronné Avatar de schniouf
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2003
    Messages
    382
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : Luxembourg

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2003
    Messages : 382
    Par défaut
    String req = "select * from produit where id_produit in ?"

    List codesProduits = new ArrayList();
    codesProduits.toString().replace('[',' ');
    codesProduits.toString().replace(']',' ');

    req += codesProduits.toString();
    Ca ne fonctionnera pas, il faut d'abord récupérer la valeur de codesProduits.toString() dans une variable, puis modifier cette variable.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    List codesProduits = new ArrayList();
    String s = codesProduits.toString() ;
    s = s.replace('[',' ');
    s = s.replace(']',' ');
     
    req += s;

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    214
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 214
    Par défaut
    Merci schniouf !! Ca marche super bien !!

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

Discussions similaires

  1. PreparedStatement et la méthode setString
    Par nddvlp dans le forum JDBC
    Réponses: 4
    Dernier message: 13/01/2015, 10h31
  2. preparedStatement.setString change le charset ?
    Par oldergod dans le forum JDBC
    Réponses: 4
    Dernier message: 05/11/2008, 02h27
  3. Passer une liste de string dans un preparedstatement
    Par thierryler dans le forum JDBC
    Réponses: 6
    Dernier message: 13/03/2008, 14h30
  4. PreparedStatement et liste
    Par tomca dans le forum JDBC
    Réponses: 10
    Dernier message: 03/05/2007, 10h18
  5. Réponses: 4
    Dernier message: 22/08/2006, 18h37

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