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

PostgreSQL Discussion :

Dernier identifiant inséré


Sujet :

PostgreSQL

  1. #1
    Membre à l'essai
    Inscrit en
    Août 2003
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Août 2003
    Messages : 16
    Points : 15
    Points
    15
    Par défaut Dernier identifiant inséré
    Bonjour à toutes et à tous,

    Dans une application Java, je cherche à récupérer le dernier identifiant inséré dans une table donnée.

    L'identifiant est de type serial.

    D'après vous, quel est le meilleur moyen de le récupérer, et de façon sûre ?

    Merci

  2. #2
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    19
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2005
    Messages : 19
    Points : 18
    Points
    18
    Par défaut
    Moi je fais une requete qui va recuperer la derniere valeur de la sequence :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select last_value from TaSequence
    La sequence est créée automatiquement lorsque tu as un type serial.

    Voila!
    La premiere fois que j'arrive a repondre a un post, j'espere que je mets pas à côté...

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    81
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 81
    Points : 82
    Points
    82
    Par défaut
    bonjour...
    tu es de bon coté claireenes mais je précise ceci:
    apparament freezeer a crée une table avec un champ du type serail. donc postgres crée une séquence avec un nom du type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <schéma>.<nom de la table>_<le champ de la table>_seq
    donc si on crée cette table dans le schéma PUBLIC :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    create table public.matable (codeTable serail, nom varchar(20))
    j'aurais cette séquence :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     public.matable_codeTable_seq
    et donc pour voir le dernier identifiant inseré on utilise l'idée de claireenes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select last_value from public.matable_codeTable_seq
    cordialement.
    claireenes j'espère que ça ne sera pas ton dernier message.

  4. #4
    Expert éminent
    Avatar de GrandFather
    Inscrit en
    Mai 2004
    Messages
    4 587
    Détails du profil
    Informations personnelles :
    Âge : 54

    Informations forums :
    Inscription : Mai 2004
    Messages : 4 587
    Points : 7 103
    Points
    7 103
    Par défaut
    Bonjour,

    si le but est de retrouver le dernier numéro créé pour qu'il serve de clé étrangère dans une autre table, il est très fortement déconseillé d'aller directement lire le champ last_value dans la séquence ; d'autres sessions peuvent avoir modifié ce champ entre le moment où le champ a été incrémenté et le moment où il est lu. Il est nettement plus sûr d'utiliser la fonction currval()
    FAQ XML
    ------------
    « Le moyen le plus sûr de cacher aux autres les limites de son savoir est de ne jamais les dépasser »
    Giacomo Leopardi

  5. #5
    Membre à l'essai
    Inscrit en
    Août 2003
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Août 2003
    Messages : 16
    Points : 15
    Points
    15
    Par défaut
    Merci à tous pour vos réponses.

    Ce qui m'interressait le plus, c'était de savoir si lastval (ou currval) renvoyait l'identifiant de la table d'une requête sql INSERT.

    J'avais peur du cas suivant (ordre chronologique important) :

    Mon programme fait une requete INSERT
    Un autre programme fait une requete INSERT sur la meme table
    SELECT lastval me renvoie la valeur de la deuxième requete INSERT.

    Il est bien indiqué que lastval renvoie le dernier id de la session en cours. Donc le cas que j'ai évoqué est éronné

  6. #6
    Expert éminent
    Avatar de GrandFather
    Inscrit en
    Mai 2004
    Messages
    4 587
    Détails du profil
    Informations personnelles :
    Âge : 54

    Informations forums :
    Inscription : Mai 2004
    Messages : 4 587
    Points : 7 103
    Points
    7 103
    Par défaut
    Citation Envoyé par creezeer
    J'avais peur du cas suivant (ordre chronologique important) :
    C'est bien pour éviter ce cas de figure que currval() et lastval() ont été conçus.

    Le SELECT last_value est extrêmement dangereux, puisqu'il peut te corrompre une base de données très facilement si tu utilises la valeur retournée pour servir de clé étrangère.
    FAQ XML
    ------------
    « Le moyen le plus sûr de cacher aux autres les limites de son savoir est de ne jamais les dépasser »
    Giacomo Leopardi

  7. #7
    Membre à l'essai
    Inscrit en
    Août 2003
    Messages
    16
    Détails du profil
    Informations forums :
    Inscription : Août 2003
    Messages : 16
    Points : 15
    Points
    15
    Par défaut
    Je suis ton conseil, j'utilise currval

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

Discussions similaires

  1. [ZF 1.7] Dernier identifiant inséré
    Par MaT$oN dans le forum Zend_Db
    Réponses: 4
    Dernier message: 10/03/2009, 18h33
  2. Réponses: 5
    Dernier message: 01/02/2005, 18h29
  3. Récupérer le dernier numéro inséré
    Par Hell dans le forum Access
    Réponses: 4
    Dernier message: 09/01/2005, 16h45
  4. Comment récupérer l'index du dernier élément inséré ?
    Par Didier100 dans le forum Bases de données
    Réponses: 4
    Dernier message: 15/07/2004, 23h41
  5. Connaitre le dernier id inséré
    Par royrremi dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 10/05/2004, 17h38

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