ホームページ > データベース > mysql チュートリアル > PostgreSQL の DEFERRABLE 主キー チェックの強制はどのように機能しますか?

PostgreSQL の DEFERRABLE 主キー チェックの強制はどのように機能しますか?

Linda Hamilton
リリース: 2025-01-06 09:16:39
オリジナル
444 人が閲覧しました

How Does PostgreSQL's DEFERRABLE Primary Key Check Enforcement Work?

DEFERRABLE 主キーチェックの強制

DEFERRABLE 主キー制約または一意キー制約の動作は、その仕様によって異なります。 PostgreSQL では、次の適用シナリオを検討します。

1. DEFERRABLE INITIALLY IMMEDIATE

DEFERRABLE INITIALLY IMMEDIATE の制約は、ご想像のとおり、各行の更新ではなく、各ステートメントの後に適用されます。これは、次のことを意味します。

  • 複数の行を変更する UPDATE ステートメントの例では、すべての更新が同じステートメント内で行われるため、制約に違反しません。
  • 同様に、CTE を変更するデータも機能します。制約に違反する別のステートメントがない限り、意図したとおりです。

2. DEFERRABLE INITIALLY DEFERRED

DEFERRABLE INITIALLY DEFERRED の制約はトランザクションの終了時に適用され、同じトランザクション内で複数の更新が可能になります。これは、複数のステートメントにわたって制約を適用する場合に便利です。

3.遅延不可能な制約

NOT DEFERRABLE として宣言された制約は、行が更新されるたびにチェックされ、より厳格になります。これにより、コマンドの最後に制約が満たされる場合でも、制約違反が発生する可能性があります。

歴史的観点

PostgreSQL の以前のバージョンでは、遅延不可能な制約行が更新されるたびにチェックも行われました。この動作はバグと考えられ、PostgreSQL 9.1 で修正されました。

実用的な意味

  • 標準準拠の動作については、DEFERRABLE INITIALLY IMMEDIATE 制約を使用してください。
  • FOREIGN KEY 制約が必要な場合、参照される列遅延不可の一意キー制約または主キー制約の一部である必要があります。
  • DEFERRABLE INITIALLY DEFERRED 制約は、単一トランザクションで複数の更新を許可することでパフォーマンスを向上させることができます。

以上がPostgreSQL の DEFERRABLE 主キー チェックの強制はどのように機能しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート