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







			
			
			
			 
			
				
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
Moi je fais une requete qui va recuperer la derniere valeur de la sequence :
La sequence est créée automatiquement lorsque tu as un type serial.
Code : Sélectionner tout - Visualiser dans une fenêtre à part select last_value from TaSequence
Voila!
La premiere fois que j'arrive a repondre a un post, j'espere que je mets pas à côté...
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 :
donc si on crée cette table dans le schéma PUBLIC :
Code : Sélectionner tout - Visualiser dans une fenêtre à part <schéma>.<nom de la table>_<le champ de la table>_seq
j'aurais cette séquence :
Code : Sélectionner tout - Visualiser dans une fenêtre à part create table public.matable (codeTable serail, nom varchar(20))
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 public.matable_codeTable_seq
cordialement.
Code : Sélectionner tout - Visualiser dans une fenêtre à part select last_value from public.matable_codeTable_seq
claireenes j'espère que ça ne sera pas ton dernier message.
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







			
			
			
			 
			
				
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é
C'est bien pour éviter ce cas de figure que currval() et lastval() ont été conçus.Envoyé par creezeer
![]()
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







			
			
			
			 
			
				
Je suis ton conseil, j'utilise currval![]()
Partager