チェック制約のサブクエリ: 代替ソリューションの探索
チェック制約は、列に挿入または更新できる値を制限することでデータの整合性を強制します。サブクエリは複雑な条件を指定する強力な方法を提供しますが、通常、SQL Server のチェック制約内では使用できません。この制限により、他のテーブルに対してデータの整合性を強制するという課題が生じます。
解決策の 1 つは、トリガーを使用することです。ただし、トリガーにより、追加のオーバーヘッドとパフォーマンスへの影響が生じる可能性があります。代わりに、スカラー関数を利用してサブクエリをカプセル化し、チェック制約で使用できるブール値を返すこともできます。
このアプローチを説明するために、列 (MyField) の値が正しいかどうかを検証するチェック制約を考えてみましょう。 ) は別のテーブル (Table2) に存在します。このチェックを実行する関数を作成する方法は次のとおりです。
CREATE FUNCTION myFunction(@Field DATATYPE(?)) RETURNS VARCHAR(5) AS BEGIN IF EXISTS (SELECT * FROM Table2 WHERE MYFIELD = @field) return 'True' return 'False' END
この関数はパラメータを受け取り、Table2 内のその存在を確認し、ブール値を返します。次に、この関数をチェック制約に組み込むことができます。
ALTER TABLE Table1 WITH CHECK ADD CONSTRAINT CK_Code CHECK (myFunction(MYFIELD) = 'True')
スカラー関数を利用すると、チェック制約内で目的のサブクエリ検証を効果的に実行でき、パフォーマンスを犠牲にしたりトリガーに頼ったりすることなくデータの整合性を確保できます。
以上がSQL Server チェック制約でサブクエリを効果的に使用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。