SQL-制約

制約は、テーブルのデータ列に適用されるルールです。これらは、テーブルに入れることができるデータのタイプを制限するために使用されます。これにより、データベース内のデータの正確性と信頼性が保証されます。

制約は、列レベルまたはテーブルレベルのいずれかになります。列レベルの制約は1つの列にのみ適用されますが、テーブルレベルの制約はテーブル全体に適用されます。

以下は、SQLで使用できる最も一般的に使用される制約の一部です。これらの制約については、SQL-RDBMSの概念の章ですでに説明していますが、この時点で修正する価値があります。

  • NOTNULL制約-列がNULL値を持つことができないようにします。

  • DEFAULT制約-何も指定されていない場合の列のデフォルト値を提供します。

  • UNIQUE制約-列のすべての値が異なることを保証します。

  • PRIMARYキー-データベーステーブルの各行/レコードを一意に識別します。

  • FOREIGNキー-指定されたデータベーステーブルのいずれかで行/レコードを一意に識別します。

  • CHECK制約-CHECK制約は、列のすべての値が特定の条件を満たすことを保証します。

  • INDEX-データベースからデータを非常に迅速に作成および取得するために使用されます。

制約は、CREATE TABLEステートメントを使用してテーブルを作成するときに指定できます。または、テーブルの作成後でも、ALTERTABLEステートメントを使用して制約を作成できます。

制約の削除

定義した制約は、DROPCONSTRAINTオプションを指定したALTERTABLEコマンドを使用して削除できます。

たとえば、EMPLOYEESテーブルの主キー制約を削除するには、次のコマンドを使用できます。

ALTER TABLE EMPLOYEES DROP CONSTRAINT EMPLOYEES_PK;

一部の実装では、特定の制約を削除するためのショートカットが提供される場合があります。たとえば、Oracleのテーブルの主キー制約を削除するには、次のコマンドを使用できます。

ALTER TABLE EMPLOYEES DROP PRIMARY KEY;

一部の実装では、制約を無効にできます。データベースから制約を永続的に削除する代わりに、制約を一時的に無効にして、後で有効にすることをお勧めします。

整合性制約

整合性制約は、リレーショナルデータベース内のデータの正確性と一貫性を確保するために使用されます。データの整合性は、参照整合性の概念を通じてリレーショナルデータベースで処理されます。

で役割を果たす整合性制約には多くの種類があります Referential Integrity (RI)。これらの制約には、主キー、外部キー、一意の制約、および上記の他の制約が含まれます。