A check constraint is a type of integrity constraint in SQL which specifies a requirement that must be met by each row in a database table. The constraint must be a predicate. It can refer to a single column, or multiple columns of the table. The result of the predicate can be either TRUE
, FALSE
, or UNKNOWN
, depending on the presence of NULLs. If the predicate evaluates to UNKNOWN
, then the constraint is not violated and the row can be inserted or updated in the table. This is contrary to predicates in WHERE
clauses in SELECT
or UPDATE
statements.
For example, in a table containing products, one could add a check constraint such that the price of a product and quantity of a product is a non-negative value:
price >= 0
quantity >= 0
If these constraints were not in place, it would be possible to have a negative price (−$30) or quantity (−3 items).
Check constraints are used to ensure the validity of data in a database and to provide data integrity. If they are used at the database level, applications that use the database will not be able to add invalid data or modify valid data so the data becomes invalid, even if the application itself accepts invalid data.