SQL Server CHECK Constraint
Databases are an essential component of modern software development, and SQL Server is one of the most widely used database management systems. In SQL Server, the CHECK constraint is a valuable tool that helps ensure data integrity.
By defining a set of conditions that a value must meet, the CHECK constraint ensures that only valid data is entered into a table. In this article, we will explore the SQL Server CHECK constraint in detail, examining its purpose, syntax, and usage.
We will also discuss how the CHECK constraint handles NULL values.
1) SQL Server CHECK constraint
The SQL Server CHECK constraint is a tool that allows a developer to specify a Boolean expression that a value in a column must satisfy in order to be considered valid. This constraint is applied to a single column and can be created on a table during the table’s creation or as an alteration to the table after it has already been created.
For example, let’s say you have a table named “Products” with a column named “UnitPrice”. You want to ensure that the values in the “UnitPrice” column are always positive.
You can create a CHECK constraint to verify if the value meets the requirement.
Below is an example of a SQL Server CHECK constraint:
CREATE TABLE Products
(
ProductID int PRIMARY KEY,
ProductName varchar(255),
UnitPrice decimal(10,2) CHECK (UnitPrice > 0)
)
The CHECK constraint in this example states that the “UnitPrice” column must have a value greater than 0. If someone tries to enter a negative value in this column, they will receive an error.
2) Using CHECK constraint to require positive values
As we have seen in the previous example, the SQL Server CHECK constraint can help to ensure that a value falls within a certain range or meets specific criteria. We can use a Boolean expression to set conditions, and if any condition is met, it is considered true.
Otherwise, it will be considered false. Only rows that satisfy the condition will be allowed in the table.
Let’s take another example. Imagine you are working on an e-commerce website and you want to ensure that all products have a positive value.
The following SQL code ensures that all products added to the “Products” table have a positive “UnitPrice”:
CREATE TABLE Products
(
ProductID int PRIMARY KEY,
ProductName varchar(255),
UnitPrice decimal(10,2) CHECK (UnitPrice > 0)
)
When a user tries to add a product to the “Products” table with a negative value for the “UnitPrice” column, the SQL Server CHECK constraint will prevent it.
3) SQL Server CHECK constraint and NULL
The SQL Server CHECK constraint handles NULL values in a unique way. A NULL value is considered unknown, and any Boolean operations performed on it will always yield UNKNOWN as the result.
Therefore, if a CHECK constraint definition includes a condition with an unknown result, SQL Server will not consider it to be either true or false. Instead, the constraint will only be enforced if the result of the condition is known.
Let’s take another example. Suppose we have to add a new column to the “Products” table named “Discount”, which contains values that can range from 0 to 100, inclusive.
The following SQL Server CHECK constraint ensures that the value entered in the “Discount” column falls within the required range:
CREATE TABLE Products
(
ProductID int PRIMARY KEY,
ProductName varchar(255),
UnitPrice decimal(10,2),
Discount decimal(3,2) CHECK (Discount >= 0 AND Discount <= 100)
)
However, if a user tries to insert a NULL value into the "Discount" column, the CHECK constraint will not be enforced. If you want to force an entry in the column, you can set the column to NOT NULL during creation.
3) CHECK constraint referring to multiple columns
SQL Server CHECK constraint can also be applied for multiple columns. This constraint can be used to define specific conditions for multiple columns simultaneously.
This helps to ensure that there is consistency in data across several columns. A perfect use case for this is to check that prices of products are always correctly entered.
In this example, suppose a new "Products" table needs to be created. The table has three columns - ProductID, UnitPrice, DiscountedPrice.
UnitPrice is the regular price for the product, and DiscountedPrice is the price with a discount applied. To ensure that all product prices are entered correctly, we can specify a CHECK constraint that ensures DiscountedPrice is less than or equal to the UnitPrice.
CREATE TABLE Products
(
ProductID int PRIMARY KEY,
UnitPrice decimal(10,2) NOT NULL,
DiscountedPrice decimal(10,2) NOT NULL,
CHECK (UnitPrice >= DiscountedPrice)
)
The CHECK constraint in this example ensures that the DiscountedPrice is always less than or equal to the UnitPrice. Table Constraints vs.
Column Constraints
Column constraints define a rule for a single column, while table constraints apply rules for several columns. Column constraints are attached to individual columns, while table constraints are applied to the entire table.
Column constraints are defined using the syntax: COLUMN_NAME CONSTRAINT CONSTRAINT_NAME CHECK (EXPRESSION), while table constraints are defined using the syntax: CONSTRAINT CONSTRAINT_NAME CHECK (EXPRESSION)
For example, here is another use case for the CHECK constraint. Imagine we have a database created to store data on banking transactions.
The table is named "Transactions" with columns such as "TransactionID," "TransactionDate," "Amount," "TransactionType," and "AccountNumber." We want to ensure that whenever a transaction is entered into the system, it is either a deposit or a withdrawal. We can use a table constraint to ensure that the "TransactionType" column always contains either deposit or withdrawal.
CREATE TABLE Transactions
(
TransactionID int PRIMARY KEY,
TransactionDate date NOT NULL,
Amount decimal(8,2) NOT NULL,
TransactionType varchar(20) NOT NULL,
AccountNumber varchar(20) NOT NULL,
CONSTRAINT TransactionType CHECK (TransactionType IN ('Deposit', 'Withdrawal'))
)
In this example, the table-level constraint ensures that the values entered in the "TransactionType" column are either "Deposit" or "Withdrawal."
4) Add CHECK constraints to an existing table
Sometimes, it is necessary to add a CHECK constraint to an existing table. This is done using the ALTER TABLE command.
The ALTER TABLE command can be used to modify the table schema by adding the constraint, ensuring data consistency. This is useful in cases where a table was created without any constraints, and you need to add a constraint for data integrity.
Here is an example of how to add CHECK constraint to an existing table in SQL Server:
ALTER TABLE Products
ADD CONSTRAINT UnitPrice CHECK (UnitPrice >= 0)
In this example, we are adding a new constraint to the "Products" table, named "UnitPrice," that ensures the UnitPrice column always contains positive values.
5) Remove CHECK constraints
Sometimes, it may be necessary to remove a CHECK constraint from a table. Removing constraints from a table can be done using the ALTER TABLE command as well.
The DROP CONSTRAINT keyword is used to remove the constraint associated with the given constraint name. Here is an example of how to remove a CHECK constraint from a table:
ALTER TABLE Products
DROP CONSTRAINT UnitPrice
In this example, we are removing the constraint named "UnitPrice" from the "Products" table.
6) Disable CHECK constraints for insert or update
There may be instances where you need to temporarily disable CHECK constraints associated with a table when inserting data. For instance, it could be when migrating data from an old database to a new database, and you need to temporarily disable constraints to allow for the import of data that would otherwise be found invalid by the constraint.
The DISABLE CONSTRAINT keyword is used to temporarily disable the CHECK constraint when inserting or updating data. Once the update or insertion is complete, we re-enable the constraint.
Here is an example of how to disable a CHECK constraint:
ALTER TABLE Products
NOCHECK CONSTRAINT UnitPrice
In this example, we are temporarily disabling the CHECK constraint named "UnitPrice" in the "Products" table. Here's an example of how to re-enable the CHECK constraint:
ALTER TABLE Products
CHECK CONSTRAINT UnitPrice
In this example, we are re-enabling the constraint named "UnitPrice" in the "Products" table. However, it is essential to exercise caution when disabling constraints, as this could lead to the entry of invalid data, which can cause issues later on.
Any update or insertion that violates the constraint and is committed to the database while the constraint is disabled cannot be corrected without disabling the constraint again.
Conclusion
The SQL Server CHECK constraint is an essential feature of SQL Server. It provides an effective way to ensure that data entered into databases is consistent and accurate.
We have explored the SQL Server CHECK constraint extensively in this article, discussing how to use it for multiple columns, column-level, and table-level constraints. We also explored the possibilities of adding and removing CHECK constraints when working on an existing table, as well as disabling constraints when inserting or updating data.
With this knowledge, you can use CHECK constraints confidently in your SQL Server databases, which will in turn lead to reliable and valid data sets. In summary, SQL Server CHECK constraints are crucial for ensuring data integrity in databases.
They provide an efficient way to validate data and prevent incorrect entries. With column and table-level constraints, developers can define multiple constraints on a single or multiple columns of a table.
Adding and removing CHECK constraints can be done through ALTER TABLE commands, while disabling constraints can be accomplished using the NOCHECK CONSTRAINT keyword. The key takeaway is that implementing CHECK constraints in SQL Server databases will improve data consistency, accuracy, and reliability, ultimately leading to better decision-making.