ホームページ >データベース >mysql チュートリアル >SQL Server の複数の列にわたって一意の制約を適用するにはどうすればよいですか?

SQL Server の複数の列にわたって一意の制約を適用するにはどうすればよいですか?

DDD
DDDオリジナル
2025-01-24 23:51:11398ブラウズ

How to Enforce a Unique Constraint Across Multiple Columns in SQL Server?

複数のSQL Server列にわたって一意性を施行

多くの場合、データベースの整合性には、複数の列値に基づいて重複する行を防ぐ必要があります。この記事では、

表のPersonNumber列とActiveの列全体に一意の制約を実施する方法を示しています。 一意の制約を実装するPerson

既存の重複エントリを削除した後、これらの方法のいずれかを使用して制約を適用します。

ステートメント:
    これは、既存のテーブルに制約を直接追加します。
  • ALTER TABLE

    ステートメント:
    <code class="language-sql">ALTER TABLE dbo.Person ADD CONSTRAINT uq_Person_NumberActive UNIQUE (PersonNumber, Active);</code>
    これにより、一意のインデックスが作成されます。
  • CREATE UNIQUE INDEX代替アプローチと最適化

    <code class="language-sql">CREATE UNIQUE INDEX uq_Person_NumberActive ON dbo.Person (PersonNumber, Active);</code>
    上記の方法は効果的ですが、これらの機能強化を考慮してください:

パフォーマンス:プロアクティブな重複チェック

挿入を試みることは、

ブロック内の例外を回避することでパフォーマンスを改善することができます。
  • トリガー:anトリガーにより、条件付き挿入ロジックが可能になり、例外がアプリケーションレイヤーに伝播するのを防ぎます。 これにより、より堅牢なエラー処理メカニズムが提供されます TRY...CATCH
  • 例示的な例
  • INSTEAD OFこの例は、アクションの固有の制約を示しています: INSTEAD OF これにより、
ステータスの一意の組み合わせごとに1つのレコードのみが存在することが保証されます。 複製を挿入しようとすると、エラーが発生します。

を実際のスキーマとテーブル名に置き換えることを忘れないでください。

以上がSQL Server の複数の列にわたって一意の制約を適用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。