使用されるすべてのシーケンスがそれぞれの列によって所有されていると仮定します。 serial
を介して またはidentity
属性の場合、これを使用して、現在のデータベース内のすべての(所有されている)シーケンスをリセットできます。
with sequences as (
select *
from (
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 not in ('pg_catalog', 'information_schema')
) t
where col_sequence is not null
), maxvals as (
select table_schema, table_name, column_name, col_sequence,
(xpath('/row/max/text()',
query_to_xml(format('select max(%I) from %I.%I', column_name, table_schema, table_name), true, true, ''))
)[1]::text::bigint as max_val
from sequences
)
select table_schema,
table_name,
column_name,
col_sequence,
coalesce(max_val, 0) as max_val,
setval(col_sequence, coalesce(max_val, 1)) --<< this will change the sequence
from maxvals;
最初の部分は、列が所有するすべてのシーケンスを選択します。次に、2番目の部分はquery_to_xml()
を使用します そのシーケンスに関連付けられている列の最大値を取得します。そして最後のSELECTは、setval()
を使用して、その最大値を各シーケンスに適用します。 。
setval()
なしで実行することをお勧めします 最初に電話して、すべてが必要なものかどうかを確認してください。