feature #3: create table article

This commit is contained in:
2019-07-25 18:03:04 +02:00
parent 0d2c46538f
commit e3daf16035
2 changed files with 37 additions and 0 deletions

View File

@@ -0,0 +1,33 @@
create or replace function generate_version_number(tablename regclass, version_id uuid) returns int
language plpgsql as
$$
begin
return random(); -- TODO
end;
$$;
create or replace function set_version_number() returns trigger
language plpgsql as
$$
begin
new.version_number = generate_version_number(TG_TABLE_NAME::regclass, new.version_id);
end;
$$;
create table article
(
id uuid default uuid_generate_v4() not null,
version_id uuid default uuid_generate_v4() not null,
version_number int not null,
title text not null,
annonymous boolean default false not null,
content text not null,
description text,
tags varchar(32)[] default '{}' not null,
created_at timestamptz default now() not null
);
CREATE TRIGGER generate_version_number_trigger
BEFORE INSERT
ON article
EXECUTE PROCEDURE set_version_number();