SQL Server: Check Constraints
In SQL Server, a check constraint is used to specify the limitation on the values of a column when inserting or updating.
For example, use check constraint if a column required a date value in specific range, or a value must be in some specific format e.g. value in the zip_code column must be of 5 digits.
CONSTRAINT <constraint_name> CHECK(<boolean_expression>)
Check constraints can be created with CREATE or ALTER TABLE T-SQL. Add check constraints after all columns definition in the CREATE TABLE statement.
The following CREATE TABLE statement defines a check constraint on the Salary
column of the Employee
table.
CREATE TABLE Employee(EmployeeID int,
FirstName nvarchar(50) NOT NULL,
LastName nvarchar(50) NOT NULL,
EMail nvarchar(50),
Salary int,
ADD CONSTRAINT CHK_Emp_Salary CHECK(Salary > 2000 AND Salary < 4000))
The following ALTER TABLE statement adds a check constraint on the Salary
column of the Employee
table where values must be evaluated to True
for a boolean expression Salary > 2000 AND Salary < 4000
.
ALTER TABLE Employee
ADD CONSTRAINT CHK_Emp_Salary
CHECK (Salary > 2000 AND Salary < 4000);
Now, if you try to insert or update a record in the Employee
table where Salary
is not within the specified range, then it will raise the following error.
The INSERT statement conflicted with the CHECK constraint "CHK_Emp_Salary". The conflict occurred in database "HR", table "dbo.Employee", column 'Salary'. The statement has been terminated.
Important Points:
- A check constraint can be created with any logical Boolean that returns
True
orFalse
based on logical operators. For example, a boolean expressionSalary > 2000 and Salary < 4000
specifies that the value in theSalary
column must be more than2000
and less than4000
. - A boolean expression of check constraint can use multiple columns.
- A single column can have multiple check constraints.
- Check constraints reject values that evaluate to False. If you try to insert a value outside the check constraint value range then SQL engine throws an error stating that the insert statement conflicted with the CHECK constraint and the statement was terminated.
- A check constraint does not evaluate a NULL value. So NULL can be inserted without restriction. Use NOT NULL constraint to restrict the NULL values.
- Check constraints are not validated during the Delete statements.
- You can enable or disable check constraints instead of deleting them.
Create Check Constraint Using SSMS
Step 1: In the Object explorer, expand the table folder and right-click on Constraints
folder and select New Constraint
, as shown below.
data:image/s3,"s3://crabby-images/648de/648dea85961e08638814f126c9e8a2d7cd926284" alt="SQL Server Check Constraint"
Step 2: The Check Constraint dialog box opens. Select Expressions
and click on ellipses ...
, as shown below.
data:image/s3,"s3://crabby-images/6c2ea/6c2ea7d1abf48432826a0df500ff7188ac84cc0d" alt="Add Check Constraint Expression"
Step 3: In the "Check constraint Expression" dialog box, type SQL expression for the check constraint. For example, for the Salary
column of the Employee
table, enter the salary range as Salary > 2000 and Salary < 4000
and Click OK.
data:image/s3,"s3://crabby-images/1e305/1e305c92aeb7fb5906c577aaabb22cfd36af5533" alt="Add Check Constraint Expression"
Step 4: In the Identity category, you can change the name for the constraint and add a description.
data:image/s3,"s3://crabby-images/8aed0/8aed04553096020a78dffee4daed007c44165329" alt="Add Check Constraint Name"
Step 5: In the Table Designer
section below Identity
, enable or disable check constraint, and specify when the check constraint is enforced.
Step 6: Click Close. In File menu, click Save <table name>.
Thus, you can create a check constraint on a column in a table.
Modify Check Constraints using SSMS
Open SSMS (SQL Server Management Studio), right-click on the table name and select Design
to open it in the table designer.
Now, right-click on the table designer and select Check Constraints...
, as shown below.
data:image/s3,"s3://crabby-images/d0506/d05067f869f0b7cf45b6c7aaea6b2f1b895842dc" alt="Modify Check Constraint"
This will open "Check Constraint" dialog box where you can edit an expression, re-name the constraint, or disable the constraint for any updates or inserts, as shown below.
data:image/s3,"s3://crabby-images/8df4e/8df4ea50d9dd1fccaa78149fc06b2da5d7869e52" alt="Modify Check Constraint"
After modification, click Close and save the changes.
Enable or Disable Check Constraint
Once you create a check constraint, you can disable it. Disabling check constraint will not enforce the check constraint on insert or update. You can re-enable it later on when needed.
ALTER TABLE <table_name>
NOCHECK CONSTRAINT <constraint_name>;
The following disables the CHK_Emp_Salary
constraint.
ALTER TABLE Employee
NOCHECK CONSTRAINT CHK_Emp_Salary;
To disable a check constraint in SSMS, select "No" for the "Check Existing Data On Creation Or Re-Enabling". Select "Yes" to re-enable it, as shown below.
data:image/s3,"s3://crabby-images/9a50b/9a50b5dcbc259d345ecba310a31ebece6dc710b1" alt="Enable/Disable Check Constraint"
Delete Check Constraint Using SSMS
Use the DROP CONSTRAINT statement in the ALTER TABLE statement to delete existing check constraints.
ALTER TABLE <table-name>
DROP CONSTRAINT <constraint_name>;
The following deletes a check constraint CHK_Emp_Salary in the Employee table.
ALTER TABLE Employee
DROP CONSTRAINT CHK_Emp_Salary
To delete constraints using SQL Server Management Studio, expand the table having the constraint to be deleted.
data:image/s3,"s3://crabby-images/10d50/10d500679ed6d130571cf402759cd0b66b842af6" alt="Delete Check Constraint"
Now, expand Constraints node and right-click on the constraint to be deleted and click Delete.
data:image/s3,"s3://crabby-images/e69b0/e69b0c6e50a2b828db29fbb9dd1a9d6444fa887e" alt="Delete Check Constraint"
In the Delete Object dialog box, click Ok to delete a constraint.