PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Valor padrão para a função postgres da coluna com argumento


Infelizmente, você não pode fazer isso porque (para a documentação ):

Você pode usar um gatilho, por exemplo:
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)