Précédent   Forum des professionnels en informatique > Bases de données > PostgreSQL
PostgreSQL Forum PostgreSQL. Avant de poster -> F.A.Q PostGreSQL Tutoriels PostGreSQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 29/05/2006, 18h09   #1
Invité régulier
 
Inscription : août 2003
Messages : 16
Détails du profil
Informations forums :
Inscription : août 2003
Messages : 16
Points : 7
Points : 7
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
creezeer est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/05/2006, 11h59   #2
Invité régulier
 
Inscription : mai 2005
Messages : 19
Détails du profil
Informations forums :
Inscription : mai 2005
Messages : 19
Points : 8
Points : 8
Moi je fais une requete qui va recuperer la derniere valeur de la sequence :

Code :
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é...
claireenes est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/05/2006, 13h01   #3
Membre du Club
 
Inscription : décembre 2005
Messages : 81
Détails du profil
Informations forums :
Inscription : décembre 2005
Messages : 81
Points : 66
Points : 66
Envoyer un message via MSN à jarod_ab
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 :
<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 :
CREATE TABLE public.matable (codeTable serail, nom varchar(20))
j'aurais cette séquence :
Code :
 public.matable_codeTable_seq
et donc pour voir le dernier identifiant inseré on utilise l'idée de claireenes :
Code :
SELECT last_value FROM public.matable_codeTable_seq
cordialement.
claireenes j'espère que ça ne sera pas ton dernier message.
jarod_ab est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/05/2006, 13h45   #4
Expert Confirmé Sénior
 
Avatar de GrandFather
 
Inscription : mai 2004
Messages : 4 490
Détails du profil
Informations personnelles :
Âge : 42

Informations forums :
Inscription : mai 2004
Messages : 4 490
Points : 5 049
Points : 5 049
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
GrandFather est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/05/2006, 18h17   #5
Invité régulier
 
Inscription : août 2003
Messages : 16
Détails du profil
Informations forums :
Inscription : août 2003
Messages : 16
Points : 7
Points : 7
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é
creezeer est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/05/2006, 18h31   #6
Expert Confirmé Sénior
 
Avatar de GrandFather
 
Inscription : mai 2004
Messages : 4 490
Détails du profil
Informations personnelles :
Âge : 42

Informations forums :
Inscription : mai 2004
Messages : 4 490
Points : 5 049
Points : 5 049
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
GrandFather est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/05/2006, 18h32   #7
Invité régulier
 
Inscription : août 2003
Messages : 16
Détails du profil
Informations forums :
Inscription : août 2003
Messages : 16
Points : 7
Points : 7
Je suis ton conseil, j'utilise currval
creezeer est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 21h48.


 
 
 
 
Partenaires

Hébergement Web