ホームページ >データベース >mysql チュートリアル >特定の条件が満たされた場合にのみテーブル列に一意制約を作成するにはどうすればよいですか?
多くの場合、データベース設計ではテーブル列に一意の制約が必要ですが、それは特定の状況下でのみ必要です。 これを例で説明してみましょう:
列 Table
、ID
、および Name
を含むテーブル RecordStatus
について考えます。 RecordStatus
は 1 (アクティブ) または 2 (削除) です。 目的は、アクティブなレコード (ID
= 1) に対してのみ RecordStatus
列の一意性を強制し、削除されたレコードの重複を許可することです。
トリガーでもこれを実現できますが、より効率的で堅牢なソリューションは、フィルターされたインデックスを使用することです。
フィルターされたインデックスは、フィルター条件によって定義されたテーブル データのサブセットにインデックスを作成します。これにより、インデックス作成を正確に制御でき、条件付きの一意制約または主キー制約に最適です。
ID
が 1 の場合にのみ RecordStatus
に一意性を適用するには、次のコマンドを使用します。
<code class="language-sql">CREATE UNIQUE INDEX MyIndex ON MyTable(ID) WHERE RecordStatus = 1;</code>
これにより、ID
列に一意のインデックスが作成されますが、RecordStatus
が 1 に等しい行のみが考慮されます。
ID
= 1 で重複した RecordStatus
値を挿入しようとすると、次のようなエラーが発生します。
<code>Msg 2601, Level 14, State 1, Line 13 Cannot insert duplicate key row in object 'dbo.MyTable' with unique index 'MyIndex'. The duplicate key value is (9999).</code>
フィルターされたインデックスは、条件付き一意制約を作成するためのクリーンで効率的なアプローチを提供します。 これらは、トリガーに伴うパフォーマンスのオーバーヘッドを発生させることなくデータの整合性を強化し、複雑なデータベース要件に対してよりスケーラブルで保守可能なソリューションを提供します。 フィルター条件を正確に定義することで、特定のビジネス ルールに完全に合わせて一意性を選択的に適用できます。
以上が特定の条件が満たされた場合にのみテーブル列に一意制約を作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。