sql >> Base de Datos >  >> RDS >> PostgreSQL

Cómo actualizar masivamente el ID de secuencia postgreSQL para todas las tablas

Suponiendo que todas las secuencias utilizadas pertenecen a las respectivas columnas, p. a través de un serial o identity atributo, puede utilizar esto, para restablecer todas las secuencias (propiedad) en la base de datos actual.

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;

La primera parte selecciona todas las secuencias que pertenecen a una columna. La segunda parte luego usa query_to_xml() para obtener el valor máximo de la columna asociada con esa secuencia. Y el SELECT final luego aplica ese valor máximo a cada secuencia usando setval() .

Es posible que desee ejecutar eso sin el setval() llama primero para ver si todo está como lo necesitas.