SQL Server: Unique Key Constraints
The Unique Constraint ensures the uniqueness of all values and no duplicate values are entered in a column of a table.
The unique constraints can be created using CREATE or ALTER TABLE T-SQL. Add unique constraints after columns definitions in the CREATE TABLE statement.
CONSTRAINT <constraint_name> UNIQE(<column_name>)
The following CREATE TABLE statement defines a unique key constraint on the PhoneNo
column of the Employee
table.
CREATE TABLE Employee(EmployeeID int,
FirstName nvarchar(50) NOT NULL,
LastName nvarchar(50) NOT NULL,
EMail nvarchar(50),
PhoneNo varchar(15),
ADD CONSTRAINT UNQ_Emp_Phone Unique(PhoneNo))
The following ALTER TABLE statement adds a unique constraint on the PhoneNo
column of the existing Employee
table.
ALTER TABLE Employee
ADD CONSTRAINT UNQ_Emp_Phone Unique(PhoneNo)
Now, if you try to insert or update a record in the Employee
table where Phone
is not within the specified range, then it will raise the following error.
Violation of UNIQUE KEY constraint 'UNQ_Emp_Phone'. Cannot insert duplicate key in object 'dbo.Employee'. The duplicate key value is (123.123.1834). The statement has been terminated.
Important Points:
- Both Unique constraint and Primary key constraint enforce uniqueness. It is recommended to use Unique constraint instead of Primary key constraint whenever you want to enforce uniqueness in a column.
- Unlike Primary key constraint, Unique constraints allow only one NULL value.
- A unique index is automatically created when a unique key constraint is created.
- SQL Server raises an error whenever a duplicate value is inserted or updated.
- When a Unique index is added to an existing column in a table, the database engine first checks for the uniqueness of the specified column data. If a duplicate entry is found, then the engine returns an error and does not add the constraint.
- A Unique key in a table can be referenced by a Foreign Key from another table.
Create Unique Constraint Using SSMS
Step 1: Open SSMS, login to a database. In the Object Explorer, expand the table folder and right-click on a table where you want to add a unique constraint and select Design
to open it in a table designer.
data:image/s3,"s3://crabby-images/e6c4a/e6c4a775043ff86e5ac825601767e4d9df786fdc" alt="SQL Server Unique Key Constraint"
Now, right-click on the table designer and select Indexes/Keys
,as shown below.
data:image/s3,"s3://crabby-images/0348f/0348fb3db2f932c259444c57259c89b45756a244" alt="SQL Server Unique Key Constraint"
Step 2: In the "Indexes/Keys" dialog box, select PhoneNo
column in the Columns
property.
Next, select Unique Key
type to apply the unique key constraint on the PhoneNo
column.
data:image/s3,"s3://crabby-images/2880e/2880ee669a3c79a3645f1efb2e037cfb0ec7387f" alt="Add Unique Key Constraint"
Step 3: give the name of a constraint in the name
property.
data:image/s3,"s3://crabby-images/57b19/57b19d5820acd04af1a730cb4eda8dde5787b216" alt="Add Unique Constraint Expression"
Click Close and Save the table.
Thus, you can create an unique key constraint on a column in a table.
Delete Unique Key Constraint
Use the DROP CONSTRAINT statement in the ALTER TABLE statement to delete existing unique constraints.
ALTER TABLE <table-name>
DROP CONSTRAINT <constraint_name>;
The following deletes a unique key constraint UNQ_Emp_Phone
in the Employee
table.
ALTER TABLE Employee
DROP CONSTRAINT UNQ_Emp_Phone;
To delete constraints using SQL Server Management Studio, expand the table having the constraint to be deleted.
Now, expand Keys
folder and right-click on a constraint to be deleted and click Delete.
data:image/s3,"s3://crabby-images/3f938/3f9386b23ffaef0593baeb01af02dec505ee12b1" alt="Delete Unique Key Constraints"
This will open "Delete Object" dialog box, as shown below.
data:image/s3,"s3://crabby-images/351fa/351fa4e56bfbf3828114bac7e1cd401a6a20ef88" alt="Delete Unique Key Constraint"
In the "Delete Object" dialog box, click Ok to delete a constraint.