PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

Valore predefinito per la funzione postgres della colonna con argomento

Sfortunatamente, non puoi farlo, a causa (per la documentazione ):

Puoi utilizzare un trigger, ad esempio:

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)