sql >> Database >  >> RDS >> PostgreSQL

Volgorde-ID postgreSQL voor alle tabellen in bulk bijwerken

Ervan uitgaande dat alle gebruikte sequenties eigendom zijn van de respectieve kolommen, b.v. via een serial of identity attribuut, kunt u dit gebruiken om alle (eigen) sequenties in de huidige database te resetten.

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;

Het eerste deel selecteert alle reeksen die eigendom zijn van een kolom. Het tweede deel gebruikt dan query_to_xml() om de maximale waarde te krijgen voor de kolom die aan die reeks is gekoppeld. En de laatste SELECT past dan die maximale waarde toe op elke reeks met behulp van setval() .

Misschien wilt u dat uitvoeren zonder de setval() bel eerst om te zien of alles naar wens is.



  1. SQL Server:Query snel, maar traag van procedure

  2. Gegevens koppelen aan of importeren uit Salesforce

  3. Door Oracle ondersteunde versiesmatrix

  4. Open source-gegevens worden volwassen:kiezen voor MySQL, NoSQL of beide