sql >> データベース >  >> RDS >> PostgreSQL

すべてのテーブルのシーケンスIDpostgreSQLを一括更新する方法

    使用されるすべてのシーケンスがそれぞれの列によって所有されていると仮定します。 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()なしで実行することをお勧めします 最初に電話して、すべてが必要なものかどうかを確認してください。



    1. SQL算術演算子

    2. 例を使用して説明されたSQLDROPインデックス、DROPテーブル、およびDROPデータベースステートメント

    3. SQLServer2008の列の千単位の区切り記号

    4. 複数の1対1を作成する方法