Column Constraint Declarations
Column constraints restrict the values that can be legally stored in a column. The clauses used to do this are shown following in the syntax portion.
col_constraint:
[CONSTRAINT constraint_name] col_constraint_type
col_constraint_type:
[NOT] NULL | key_spec
| refs_spec
Components
constraint_name | Optional name for a column constraint. |
NULL | The column is allowed to contain null values. This is the default constraint and is not required. For more information on NULL values, refer to the NULL Values section. |
NOT NULL | The column is not allowed to contain null values. This means that either a default clause must be specified for the column (of course, DEFAULT NULL is not allowed) or a value for the column must always be specified in an INSERT statement on the table. For more information on NULL values, refer to the NULL Values section. |
key_spec | Indexes can be defined to allow for fast navigation or to guarantee no duplicate entries depending on the index type. For more information, refer to the Key (Index) Specification section. |
refs_spec | References (foreign indexes) can be defined to allow for fast navigation based on relationship or to validate a correct range of data values for a given field or column. For more information, refer to the Foreign Key (References) Specification section. |
The column constraint types of key_spec and refs_spec are not allowed on structured user-defined types. (See CREATE TYPE).