「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > テーブルの行と同期してポストグレスプライマリキーシーケンスをリセットする方法は?

テーブルの行と同期してポストグレスプライマリキーシーケンスをリセットする方法は?

2025-04-17に投稿されました
ブラウズ:605

How Can I Reset a Postgres Primary Key Sequence Out of Sync with Table Rows?

PostgreSQLプライマリキーシーケンスの不一致

の解決

テーブルの行に誤って調整された主要なキーシーケンスは、イライラする重複キーエラーを引き起こす可能性があります。これは、多くの場合、シーケンスの整合性が保存されていないデータのインポートまたは復元中に発生します。 修正方法は次のとおりです。

1。最高のIDを見つける:

max()関数を使用して、テーブル内の最大のIDを識別します。

SELECT MAX(id) FROM your_table;

2。シーケンスの次の値を取得します:

このクエリは、シーケンスの次の生成値を示しています:

SELECT nextval('your_table_id_seq');

3。シーケンスをリセット(必要に応じて):

シーケンスの次の値がテーブルの最大IDよりも小さい場合、トランザクション内でシーケンスをリセットして、同時挿入を防止します。

始める; 排他的モードでテーブルyour_tableをロックします。 select setVal( 'your_table_id_seq'、(selectest(max(your_id)、nextval( 'your_table_id_seq')-1)from your_table)); 専念;
BEGIN;
LOCK TABLE your_table IN EXCLUSIVE MODE;
SELECT setval('your_table_id_seq', (SELECT GREATEST(MAX(your_id), nextval('your_table_id_seq') - 1) FROM your_table));
COMMIT;
出典:

Rubyフォーラムのディスカッションから適応。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3