Maison > base de données > tutoriel mysql > Comment créer des séquences PostgreSQL dépendantes d'une autre colonne à l'aide de déclencheurs ?

Comment créer des séquences PostgreSQL dépendantes d'une autre colonne à l'aide de déclencheurs ?

Patricia Arquette
Libérer: 2025-01-24 06:10:11
original
933 Les gens l'ont consulté

How to Create PostgreSQL Sequences Dependent on Another Column Using Triggers?

Séquence PostgreSQL basée sur une autre colonne

Dans PostgreSQL, vous pouvez créer une séquence qui dépend d'une autre colonne via un déclencheur. Considérez la structure de tableau suivante :

列名 数据类型 说明
id integer 主键,外键关联其他表
seq integer 每个ID都有其自身的seq编号
data text 一些文本数据,与序列无关

L'id seq constitue une clé unique combinée.

Afin d'obtenir les résultats attendus, deux tableaux doivent être créés : les choses et les trucs.

Créer un tableau :

<code class="language-sql">CREATE TABLE things (
    id   serial primary key,
    name text
);

CREATE TABLE stuff (
    id       integer references things,
    seq      integer NOT NULL,
    notes    text,
    PRIMARY KEY (id, seq)
);</code>
Copier après la connexion

Créer un déclencheur de séquence :

Définissez un déclencheur sur la table des objets pour créer une nouvelle séquence pour chaque ligne de données insérées :

<code class="language-sql">CREATE FUNCTION make_thing_seq() RETURNS trigger
LANGUAGE plpgsql
AS $$
begin
  execute format('create sequence thing_seq_%s', NEW.id);
  return NEW;
end
$$;

CREATE TRIGGER make_thing_seq AFTER INSERT ON things FOR EACH ROW EXECUTE PROCEDURE make_thing_seq();</code>
Copier après la connexion

Déclencheur de séquence de remplissage :

Enfin, créez un déclencheur sur la table des trucs, en veillant à utiliser la bonne séquence pour chaque insertion :

<code class="language-sql">CREATE FUNCTION fill_in_stuff_seq() RETURNS trigger
LANGUAGE plpgsql
AS $$
begin
  NEW.seq := nextval('thing_seq_' || NEW.id);
  RETURN NEW;
end
$$;

CREATE TRIGGER fill_in_stuff_seq BEFORE INSERT ON stuff FOR EACH ROW EXECUTE PROCEDURE fill_in_stuff_seq();</code>
Copier après la connexion

Démo :

Les données insérées dans les tables d'objets et de trucs créeront et utiliseront les séquences correspondantes. Par exemple :

<code class="language-sql">insert into things (name) values ('Joe');
insert into things (name) values ('Bob');

insert into stuff (id, notes) values (1, 'Keychain');
insert into stuff (id, notes) values (1, 'Pet goat');
insert into stuff (id, notes) values (2, 'Family photo');
insert into stuff (id, notes) values (1, 'Redundant lawnmower');</code>
Copier après la connexion

Le résultat sera :

<code>| id | seq | notes |
|---|---|---|
| 1 | 1 | Keychain |
| 1 | 2 | Pet goat |
| 2 | 1 | Family photo |
| 1 | 3 | Redundant lawnmower |</code>
Copier après la connexion

Cette approche crée efficacement une séquence basée sur la colonne id de la table des choses, garantissant qu'une séquence unique est générée pour chaque identifiant.

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal