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 :

[PostgreSQL] Utiliser generatedKeys


Sujet :

JDBC Java

  1. #1
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2009
    Messages
    540
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2009
    Messages : 540
    Points : 532
    Points
    532
    Par défaut [PostgreSQL] Utiliser generatedKeys
    Bonjour,

    je suis en train de migrer ma base de données et après plusieurs recherches et essais de mon coté, je m'en remet à vous.
    Comme dit dans le titre, je passe à PostgreSQL et je souhaite récupérer les clés générées sur une requêtes INSERT.

    Voici le code "basique" que j'utilisais avec MySQL

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    String requete = "INSERT INTO GroupeTest (titre, scenario) VALUES (?, ?)";
                PreparedStatement pstmt = getConnexion().prepareStatement(requete,
                       Statement.RETURN_GENERATED_KEYS);
                pstmt.setString(1, groupeTest.getTitre());
                pstmt.setInt(2, Integer.parseInt(contenantId.substring(1)));
                pstmt.executeUpdate();
                ResultSet generatedKeys = pstmt.getGeneratedKeys();
                if (generatedKeys.first()) {
                    groupeTest.setId(generatedKeys.getInt(1));
                }
    Le plantage se fait au niveau du generatedKeys.first() où PostgreSQL me renvoie L'opération nécessite un scrollable ResultSet, mais ce ResultSet est FORWARD_ONLY. J'ai alors tenté de remplacé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Statement.RETURN_GENERATED_KEYS
    par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ResultSet.TYPE_SCROLL_INSENSITIVE
    et par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ResultSet.TYPE_SCROLL_SENSITIVE
    . J'obtiens la même erreur. J'en déduis alors que le résultSet extrait du preparedStatement n'est pas Scrollable.

    Comment faire ?
    Peut-on configurer PostgresSQL pour rendre le comportement similaire à MySQL sachant que je parcours la ResultSet de façon séquentielle ?

    Merci d'avance

  2. #2
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 710
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 710
    Points : 4 793
    Points
    4 793
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if (generatedKeys.first()) {
    à la place de .first()
    as-tu essayé .next() ?

    en général, les ResultSet sont positionnés avant le 1er enregistrement lors de l'ouverture
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

  3. #3
    Membre confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2009
    Messages
    540
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2009
    Messages : 540
    Points : 532
    Points
    532
    Par défaut
    Citation Envoyé par Népomucène Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if (generatedKeys.first()) {
    à la place de .first()
    as-tu essayé .next() ?

    en général, les ResultSet sont positionnés avant le 1er enregistrement lors de l'ouverture
    En effet, je n'ai pas d'exception levée. Pour le coup, puisque comme tu le dis, les ResultSet sont positionnés avant le 1er enregistrement lors de l'ouverture, res.firs() et res.next() est censé revenir au même.
    La différence est le fait que ça une ligne relative et non une absolue.

  4. #4
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 710
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 710
    Points : 4 793
    Points
    4 793
    Par défaut
    La différence est le fait que ça une ligne relative et non une absolue.
    .first() ne marche que sur des ResultSet scrollables
    par exemple si le pointeur est sur le 5ème enregistrement et que tu as besoin de revenir sur le 1er
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

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

Discussions similaires

  1. [PostgreSQL] [PostGreSQL] Utilisation de l'extension pgsql
    Par chenel80 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 22/12/2009, 10h37
  2. Cadre d'utilisation de PostGreSQL
    Par papy_tergnier dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 17/08/2005, 16h47
  3. utilisation de postgresql sur solaris?
    Par champion dans le forum PostgreSQL
    Réponses: 4
    Dernier message: 25/03/2005, 14h27
  4. [Utilisation Postgresql sur windows]
    Par xhercule dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 26/01/2004, 18h36

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