PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

Valeur par défaut pour la fonction colonne postgres avec argument

Malheureusement, vous ne pouvez pas le faire, à cause de (pour la documentation ):

Vous pouvez utiliser un déclencheur, par exemple :

create table the_table (
    trade_id int not null,
    group_id int);

create or replace function trade_id_trigger ()
returns trigger language plpgsql as $$
begin
    new.group_id:= new.trade_id+ 1;
    return new;
end $$;

create trigger trade_id_trigger
before insert or update on the_table
for each row execute procedure trade_id_trigger();

insert into the_table values (1,1);

select * from the_table;

 trade_id | group_id
----------+----------
        1 |        2
(1 row)