LAB on BASICS of CONSTRAINTS
SQL Constraints
Constraints are used to limit the type of data that can go into a table. This ensures the accuracy
and reliability of the data in the table. If there is any violation between the constraint and the data
action, the action is aborted. Constraints can be column level or table level. Column level
constraints apply to a column, and table level constraints apply to the whole table.
The following constraints are commonly used in SQL:
NOT NULL - Ensures that a column cannot have a NULL value
UNIQUE - Ensures that all values in a column are different
PRIMARY KEY - A combination of a NOT NULL and UNIQUE. Uniquely identifies
each row in a table
FOREIGN KEY - Uniquely identifies a row/record in another table
CHECK - Ensures that all values in a column satisfies a specific condition
DEFAULT - Sets a default value for a column when no value is specified
INDEX - Used to create and retrieve data from the database very quickly
SQL NOT NULL Constraint
By default, a column can hold NULL values.
The NOT NULL constraint enforces a column to NOT accept NULL values.
This enforces a field to always contain a value, which means that you cannot insert a new
record, or update a record without adding a value to this field.
NULL Value
A field with a NULL value is a field with no value. If a field in a table is optional, it is possible
to insert a new record or update a record without adding a value to this field. Then, the field will
be saved with a NULL value.
Note: A NULL value is different from a zero value or a field that contains spaces. A field with a
NULL value is one that has been left blank during record creation!
How to Test for NULL Values?
It is not possible to test for NULL values with comparison operators, such as =, <, or <>. We will
have to use the IS NULL and IS NOT NULL operators instead.
IS NULL Syntax
SELECT column_names
FROM table_name
WHERE column_name IS NULL;
Page | 1
LAB on BASICS of CONSTRAINTS
IS NOT NULL Syntax
SELECT column_names
FROM table_name
WHERE column_name IS NOT NULL;
SQL Create Constraints
Constraints can be specified when the table is created with the CREATE TABLE statement, or
after the table is created with the ALTER TABLE statement.
Syntax
CREATE TABLE table_name (
column1 datatype constraint,
column2 datatype constraint,
column3 datatype constraint,
....
);
SQL UNIQUE Constraint
The UNIQUE constraint ensures that all values in a column are different.
Both the UNIQUE and PRIMARY KEY constraints provide a guarantee for uniqueness for a
column or set of columns. A PRIMARY KEY constraint automatically has a UNIQUE
constraint. However, you can have many UNIQUE constraints per table, but only one
PRIMARY KEY constraint per table.
Example The following SQL creates a UNIQUE constraint on the "ssn" column when the
"employee" table is created:
CREATE TABLE employee (
ssn int NOT NULL UNIQUE,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),);
SQL UNIQUE Constraint on ALTER TABLE
To create a UNIQUE constraint on the "column1" column when the table is already created, use
the following SQL:
Example; ALTER TABLE tablename ADD UNIQUE (column1).
Page | 2
LAB on BASICS of CONSTRAINTS
To DROP a UNIQUE Constraint
To drop a UNIQUE constraint, use the following SQL: ALTER TABLE tablename DROP
CONSTRAINT uc_colmn1.
SQL PRIMARY KEY Constraint
The PRIMARY KEY constraint uniquely identifies each record in a table. Primary keys must
contain UNIQUE values, and cannot contain NULL values. A table can have only one primary
key, which may consist of single or multiple fields.
CREATE TABLE table name (
column name NOT NULL PRIMARY KEY,
column name datatype (size) NOT NULL,
);
To allow naming of a PRIMARY KEY constraint, and for defining a PRIMARY KEY constraint
on multiple columns, use the following SQL syntax:
CREATE TABLE table name (
column1 int NOT NULL,
column2 datatype (size) NOT NULL,
CONSTRAINT PK_tablename PRIMARY KEY (colmn1,column1)
SQL PRIMARY KEY on ALTER TABLE
To create a PRIMARY KEY constraint on the "ID" column when the table is already created, use
the following SQL:
ALTER TABLE table-name ADD PRIMARY KEY (column-name);
DROP a PRIMARY KEY Constraint
To drop a PRIMARY KEY constraint, use the following SQL:
LTER TABLE table-name DROP CONSTRAINT column-name;
SQL FOREIGN KEY Constraint
A FOREIGN KEY is a key used to link two tables together. a FOREIGN KEY is a field (or
collection of fields) in one table that refers to the PRIMARY KEY in another table. The table
containing the foreign key is called the child table, and the table containing the candidate key is
called the referenced or parent table.
Page | 3
LAB on BASICS of CONSTRAINTS
SQL FOREIGN KEY on CREATE TABLE
The following SQL creates a FOREIGN KEY on the column when the table is created:
CREATE TABLE table-name (
column1 int NOT NULL PRIMARY KEY,
column2 int NOT NULL,
column3 int FOREIGN KEY REFERENCES table2(column3)
SQL FOREIGN KEY on ALTER TABLE
To create a FOREIGN KEY constraint on the column when the table is already created, use the
following SQL:
ALTER TABLE table name ADD FOREIGN KEY (column name) REFERENCES table
name(column name);
DROP a FOREIGN KEY Constraint
To drop a FOREIGN KEY constraint, use the following SQL:
ALTER TABLE table name
DROP CONSTRAINT FK_column name;
SQL CHECK Constraint
The CHECK constraint is used to limit the value range that can be placed in a column. If you
define a CHECK constraint on a single column it allows only certain values for this column. If
you define a CHECK constraint on a table it can limit the values in certain columns based on
values in other columns in the row.
SQL CHECK on CREATE TABLE
The following SQL creates a CHECK constraint on the "column1” when the "tablename" is
created. The CHECK constraint specifies that the "column1" must only include integers greater
than 10.
CREATE TABLE TABLE-NAME (
column1 int NOT NULL CHECK (column1>10),
column2 varchar(255) NOT NULL,);
To allow naming of a CHECK constraint, and for defining a CHECK constraint on multiple
columns, use the following SQL syntax:
CREATE TABLE EMPLOYEE (
ssn int NOT NULL,
fname varchar(255) NOT NULL,
LName varchar(255),
Address varchar(255), City varchar(255),
CONSTRAINT chk_employee CHECK (SSN>10 AND ADDRESS='ARBAMINCH')
ALTER TABLE employee ADD CHECK (ssn>10)
Page | 4
LAB on BASICS of CONSTRAINTS
To drop a CHECK constraint, use the following SQL:
ALTER TABLE employee DROP CONSTRAINT chk_employee
SQL DEFAULT Constraint
The DEFAULT constraint is used to provide a default value for a column. The default value will
be added to all new records IF no other value is specified.
SQL DEFAULT on CREATE TABLE
The following SQL sets a DEFAULT value for the "address" column when the "employee" table
is created:
CREATE TABLE employee (
ssn int NOT NULL UNIQUE,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255) not null default ‘Burie’,
City varchar(255),);
Note:- The DEFAULT constraint can also be used to insert system values, by using functions
like GETDATE():
CREATE TABLE table name (
ID int NOT NULL,
todyDate date DEFAULT GETDATE()
);
SQL DEFAULT on ALTER TABLE
To create a DEFAULT constraint on the "address" column when the table is already created, use
the following SQL:
ALTER TABLE employee
ADD CONSTRAINT df_address
DEFAULT 'arbaminch' FOR address ;
DROP a DEFAULT Constraint
To drop a DEFAULT constraint, use the following SQL:
ALTER TABLE employee
ALTER COLUMN address DROP DEFAULT;
Page | 5
LAB on BASICS of CONSTRAINTS
AUTO INCREMENT Field
Auto-increment allows a unique number to be generated automatically when a new record is
inserted into a table. Often this is the primary key field that we would like to be created
automatically every time a new record is inserted. The MS SQL Server uses the IDENTITY
keyword to perform an auto-increment feature.
The following SQL statement defines the "ID" column to be an auto-increment primary key field
in the "employee" table:
CREATE TABLE employee (
ID int IDENTITY(1,1) PRIMARY KEY,
Fname varchar(255) NOT NULL,
Lname varchar(255),
Age int );
In the example above, the starting value for IDENTITY is 1, and it will increment by 1 for each
new record.
Note: To specify that the "ID" column should start at value 10 and increment by 5, change it to
IDENTITY (10, 5). To insert a new record into the "employee" table, we will NOT have to
specify a value for the "ID" column (a unique value will be added automatically):
Page | 6