Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mencipta Urutan PostgreSQL Bergantung pada Lajur Lain Menggunakan Pencetus?

Bagaimana untuk Mencipta Urutan PostgreSQL Bergantung pada Lajur Lain Menggunakan Pencetus?

Patricia Arquette
Lepaskan: 2025-01-24 06:10:11
asal
932 orang telah melayarinya

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

Jujukan PostgreSQL berdasarkan lajur lain

Dalam PostgreSQL, anda boleh mencipta jujukan yang bergantung pada lajur lain melalui pencetus. Pertimbangkan struktur jadual berikut:

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

ID seq membentuk kunci unik gabungan.

Untuk mencapai hasil yang diharapkan, dua jadual perlu dibuat: perkara dan barangan.

Buat jadual:

<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>
Salin selepas log masuk

Buat pencetus jujukan:

Tetapkan pencetus pada jadual perkara untuk mencipta urutan baharu bagi setiap baris data yang disisipkan:

<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>
Salin selepas log masuk

Pencetus jujukan isi:

Akhir sekali, buat pencetus pada jadual bahan, pastikan anda menggunakan urutan yang betul untuk setiap sisipan:

<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>
Salin selepas log masuk

Demo:

Data yang dimasukkan ke dalam jadual benda dan bahan akan mencipta dan menggunakan jujukan yang sepadan. Contohnya:

<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>
Salin selepas log masuk

Hasilnya ialah:

<code>| id | seq | notes |
|---|---|---|
| 1 | 1 | Keychain |
| 1 | 2 | Pet goat |
| 2 | 1 | Family photo |
| 1 | 3 | Redundant lawnmower |</code>
Salin selepas log masuk

Pendekatan ini berkesan mencipta jujukan berdasarkan lajur id bagi jadual perkara, memastikan jujukan unik dijana untuk setiap id.

Atas ialah kandungan terperinci Bagaimana untuk Mencipta Urutan PostgreSQL Bergantung pada Lajur Lain Menggunakan Pencetus?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan