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 :

Récupérer les auto-keys avec un preparedStatement


Sujet :

JDBC Java

  1. #1
    lvr
    lvr est déconnecté
    Membre extrêmement actif Avatar de lvr
    Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2006
    Messages
    910
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Avril 2006
    Messages : 910
    Points : 1 365
    Points
    1 365
    Par défaut Récupérer les auto-keys avec un preparedStatement
    Bonjour,

    J'essaye de faire un insert avec un preparedStatement et de récupérer les clés générées.

    La faq ici explique comment faire avec un statement normal, ce qui donnerait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    PreparedStatement prep = conn.prepareStatement("Insert into entry values (?,?)");
    prep.setString(1,"A"); prep.setString(2,"B");
    prep.executeUpdate(????,Statement.RETURN_GENERATED_KEYS);
    //Les clefs auto-générées sont retournées sous forme de ResultSet
    ResultSet clefs = prep.getGeneratedKeys();
    mais ça n'a pas de sens avec un preparedStatement, car qu'est-ce que mets comme SQL ?
    J'ai essayé le prep.getGeneratedKeys() sans le Statement.RETURN_GENERATED_KEYS, mais ça donne une erreur.

    J'ai aussi essayé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    PreparedStatement prep = conn.prepareStatement(
         "Insert into entry values (?,?); Call identity()");
    prep.executeExecute();
    mais ça me retourne une SQLException sur le prepareStatement.

    Une idée ?

  2. #2
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Points : 2 061
    Points
    2 061
    Par défaut
    Bonjour,
    La réponse se trouve dans la javaDoc !
    Pour un preparedStatement tous se fait à la création de celui-ci.
    Ton code doit donc être le suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    PreparedStatement prep = conn.prepareStatement("Insert into entry values (?,?)", Statement.RETURN_GENERATED_KEYS);
    prep.setString(1,"A"); prep.setString(2,"B");
    prep.executeUpdate();
    //Les clefs auto-générées sont retournées sous forme de ResultSet
    ResultSet clefs = prep.getGeneratedKeys();

  3. #3
    lvr
    lvr est déconnecté
    Membre extrêmement actif Avatar de lvr
    Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2006
    Messages
    910
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Avril 2006
    Messages : 910
    Points : 1 365
    Points
    1 365
    Par défaut
    Merci pour ta réponse, j'avais déjà essayé mais je reçois une "This function is not supported". La db que j'utilise est une db embarquée "hsqldb". Est-ce pour ça ?

  4. #4
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Points : 2 061
    Points
    2 061
    Par défaut
    en effet, c'est bien a cause de hsqldb !
    si c'est possible je te conseil de changer de base embarquée en passant sur H2.

    Elle est plus performante que hsqldb et elle est aussi en pure java

  5. #5
    lvr
    lvr est déconnecté
    Membre extrêmement actif Avatar de lvr
    Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2006
    Messages
    910
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Avril 2006
    Messages : 910
    Points : 1 365
    Points
    1 365
    Par défaut
    Je viens de parcourir la doc. Ca m'a l'air très bien tout ça.
    Merci. J'implémente le tout. Si ça fonctionne, je clôture l'issue.

  6. #6
    lvr
    lvr est déconnecté
    Membre extrêmement actif Avatar de lvr
    Profil pro
    Responsable de projet fonctionnel
    Inscrit en
    Avril 2006
    Messages
    910
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Responsable de projet fonctionnel
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Avril 2006
    Messages : 910
    Points : 1 365
    Points
    1 365
    Par défaut
    Passage à H2 réussit et getGeneratedKeys qui fonctionne.
    Par contre, je trouve que H2 est plus lent à démarrer que HSQLDB.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 16/11/2009, 13h58
  2. CheckBoxList : récupérer les éléments sélectionnés avec javaScript
    Par kroukse dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 13/11/2009, 17h04
  3. Réponses: 0
    Dernier message: 13/11/2009, 16h36
  4. Réponses: 4
    Dernier message: 18/02/2009, 18h14
  5. [CKEditor] Récupérer les données écrites avec fckeditor
    Par thecrazyspy dans le forum Bibliothèques & Frameworks
    Réponses: 2
    Dernier message: 06/06/2008, 14h49

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