Вам на самом деле не нужна функция для этого.С вариацией этот ответ это можно сделать с помощью одного оператора:
Сначала нам нужно найти все столбцы, которые используют последовательность в качестве значения по умолчанию:
select table_schema, table_name, column_name,
pg_get_serial_sequence(format('%I.%I', table_schema, table_name), column_name)
from information_schema.columns
where table_schema = 'public'
and column_default like 'nextval%'
Затем мы можем вычислить максимальное значение для каждого из этих столбцов, используя query_to_xml()
и использовать этот результат для вызова setval()
для каждой последовательности.
with sequences as (
select table_schema, table_name, column_name,
pg_get_serial_sequence(format('%I.%I', table_schema, table_name), column_name) as col_sequence
from information_schema.columns
where table_schema = 'public' --<< adjust for your schemas
and column_default like 'nextval%'
), maxvals as (
select table_schema, table_name, column_name, col_sequence,
(xpath('/row/max/text()',
query_to_xml(format('select coalesce(max(%I),0) from %I.%I', column_name, table_schema, table_name), true, true, ''))
)[1]::text::bigint as max_val
from sequences
where col_sequence is not null
)
select table_schema,
table_name,
column_name,
col_sequence,
max_val,
setval(col_sequence, max_val)
from maxvals;