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 :

Convertir java.util.ArrayList en java.sql.Array


Sujet :

JDBC Java

  1. #1
    Membre habitué Avatar de archer
    Ingénieur développement logiciels
    Inscrit en
    Mai 2007
    Messages
    338
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Mai 2007
    Messages : 338
    Points : 180
    Points
    180
    Par défaut Convertir java.util.ArrayList en java.sql.Array
    Bonjour,
    Je crois que l'intitulé résume mon poste. En effet j'ai besoin de convertir une ArrayList en Array afin de l’utiliser avec l'instruction IN qu'une requête SQL.

    Merci d'avance.

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    338
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2008
    Messages : 338
    Points : 402
    Points
    402
    Par défaut
    java.sql.Array est une interface donc on ne peut pas l'instancier.
    On peut récupérer un tableau à partir d'un objet Array récupéré de la base avec ResultSet.getArray("colonneArray") l'inverse me parait bizarre.
    Tu fais quoi exactement pour faire ton IN?

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

    Informations forums :
    Inscription : Décembre 2003
    Messages : 476
    Points : 595
    Points
    595
    Par défaut
    Salut,

    J'imagine ce que tu veux faire : passer par un preparedStatement et lui filer le tableau sql via setArray(Array array).
    C'est pas conseillé car même si ça marche, tu auras un code java dépendant du sgbd et des drivers que tu utilises.

    Si le tableau est à taille variable, je générerais ma requête sql à la volée en itérerant sur chaque objet de la liste. Avec des preparedStatement,tu n'échaperas pas aux concaténations de chaines et le cache servirait pas non plus à grand chose puisque le preparedStatement serait recompilé autant de fois que d'appels avec un nombre de param différent pour le in.

    Si le tableau est de taille fixe, je trouve par contre le preparedstatement plus lisible :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    PreparedStatement stmt = conn.prepareStatement(
    "select * from matable where id in (?, ?, ?)");
    stmt.setInt(1);
    stmt.setInt(2);
    stmt.setInt(3);

  4. #4
    Membre habitué Avatar de archer
    Ingénieur développement logiciels
    Inscrit en
    Mai 2007
    Messages
    338
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Mai 2007
    Messages : 338
    Points : 180
    Points
    180
    Par défaut
    Merci pour les réponses.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 26/03/2015, 10h57
  2. Réponses: 1
    Dernier message: 01/12/2012, 14h15
  3. Erreur "java.util.ArrayList cannot be cast"
    Par smile_88 dans le forum Hibernate
    Réponses: 2
    Dernier message: 17/10/2012, 00h11
  4. Réponses: 0
    Dernier message: 19/03/2010, 14h36
  5. java.util.date et java.sql.date
    Par taha1 dans le forum Langage
    Réponses: 4
    Dernier message: 26/06/2009, 13h16

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