Maison >base de données >tutoriel mysql >Comment puis-je utiliser des variables et récupérer le dernier identifiant inséré dans PostgreSQL ?

Comment puis-je utiliser des variables et récupérer le dernier identifiant inséré dans PostgreSQL ?

DDD
DDDoriginal
2025-01-24 20:18:11755parcourir

How Can I Use Variables and Retrieve the Last Inserted ID in PostgreSQL?

variable de script postgresql

Dans MS-SQL, vous pouvez utiliser le mot clé Declare pour déclarer et utiliser des variables dans la fenêtre de requête. Cela vous permet de stocker et de faire fonctionner les données dynamiquement. Par exemple, vous pouvez déclarer une variable appelée @List et attribuer une valeur, puis l'utiliser dans l'instruction SELECT pour récupérer les données en fonction de la valeur de la variable.

Utiliser des variables dans PostgreSQL

Pour implémenter des fonctions similaires dans PostgreSQL, vous pouvez utiliser la nouvelle fonction de bloc de code anonyme introduit dans la version 9.0. Cette fonctionnalité vous permet d'exécuter des blocs de code dans une instruction SQL.

Exemple:

Obtenez le dernier ID inséré
<code class="language-sql">DO $$
DECLARE v_List TEXT;
BEGIN
  v_List := 'foobar' ;
  SELECT *
  FROM   dbo.PubLists
  WHERE  Name = v_List;
  -- ...
END $$;</code>

Vous pouvez également utiliser cette fonction de bloc de code pour récupérer le dernier ID inséré après l'opération d'insertion:

Veuillez vous référer au document officiel PostgreSQL pour comprendre la discussion complète de l'utilisation des variables dans le script PostgreSQL.
<code class="language-sql">DO $$
DECLARE lastid bigint;
BEGIN
  INSERT INTO test (name) VALUES ('Test Name') 
  RETURNING id INTO lastid;

  SELECT * FROM test WHERE id = lastid;
END $$;</code>

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn