0% found this document useful (0 votes)
62 views

11 - SQL FOREIGN KEY Constraint

Uploaded by

Hsan Hlaing
Copyright
© © All Rights Reserved
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
62 views

11 - SQL FOREIGN KEY Constraint

Uploaded by

Hsan Hlaing
Copyright
© © All Rights Reserved
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 9

 Tutorials  References  Menu  Paid Courses Log in

  HTML CSS JAVASCRIPT SQL PYTHON   

SQL FOREIGN KEY Constraint


❮ Previous Next ❯

SQL FOREIGN KEY Constraint


The FOREIGN KEY constraint is used to prevent actions that would destroy links between tables.

A FOREIGN KEY is a field (or collection of fields) in one table, that refers to the PRIMARY KEY in another table.

The table with the foreign key is called the child table, and the table with the primary key is called the referenced or parent
table.

Look at the following two tables:

Persons Table
PersonID LastName FirstName Age

1 Hansen Ola 30

2 Svendson Tove 23

3 Pettersen Kari 20

Orders Table

OrderID OrderNumber PersonID

1 77895 3

2 44678 3

3 22456 2

4 24562 1

Notice that the "PersonID" column in the "Orders" table points to the "PersonID" column in the "Persons" table.

The "PersonID" column in the "Persons" table is the PRIMARY KEY in the "Persons" table.

The "PersonID" column in the "Orders" table is a FOREIGN KEY in the "Orders" table.

The FOREIGN KEY constraint prevents invalid data from being inserted into the foreign key column,
because it has to be one of
the values contained in the parent table.
SQL FOREIGN KEY on CREATE TABLE
The following SQL creates a FOREIGN KEY on the "PersonID" column when the "Orders" table is created:

MySQL:

CREATE TABLE Orders


(

   
OrderID int NOT NULL,

   
OrderNumber int NOT NULL,

   
PersonID int,

   
PRIMARY KEY (OrderID),

   
FOREIGN KEY (PersonID) REFERENCES Persons(PersonID)

);

SQL Server / Oracle / MS Access:

CREATE TABLE Orders


(

   
OrderID int NOT NULL PRIMARY KEY,

   
OrderNumber int NOT NULL,

   
PersonID int FOREIGN KEY REFERENCES Persons(PersonID)

);

To allow naming of a FOREIGN KEY constraint, and for defining a FOREIGN KEY constraint on multiple columns, use the following
SQL syntax:
MySQL / SQL Server / Oracle / MS Access:

CREATE TABLE Orders


(

   
OrderID int NOT NULL,

   
OrderNumber int NOT NULL,

   
PersonID int,

   
PRIMARY KEY (OrderID),

   
CONSTRAINT FK_PersonOrder FOREIGN KEY (PersonID)

   
REFERENCES Persons(PersonID)

);

SQL FOREIGN KEY on ALTER TABLE


To create a FOREIGN KEY constraint on the "PersonID" column when the "Orders" table is already created, use the following
SQL:

MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Orders

ADD FOREIGN KEY (PersonID)


REFERENCES Persons(PersonID);

To allow naming of a FOREIGN KEY constraint, and for defining a FOREIGN KEY constraint on multiple columns, use the following
SQL syntax:
MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Orders

ADD CONSTRAINT FK_PersonOrder

FOREIGN KEY (PersonID)


REFERENCES Persons(PersonID);

DROP a FOREIGN KEY Constraint


To drop a FOREIGN KEY constraint, use the following SQL:

MySQL:

ALTER TABLE Orders

DROP FOREIGN KEY FK_PersonOrder;

SQL Server / Oracle / MS Access:

ALTER TABLE Orders

DROP CONSTRAINT FK_PersonOrder;


❮ Previous Next ❯

Create your own website


with W3schools Spaces

Get started

COLOR PICKER
LIKE US



Get certified

by completing

a course today!

school
w3 s

1
CE

02
TI 2

R
FI .
ED

Get started

CODE GAME
Play Game

Report Error Forum About Shop

Top Tutorials Top References


HTML Tutorial
HTML Reference

CSS Tutorial
CSS Reference

JavaScript Tutorial
JavaScript Reference

How To Tutorial
SQL Reference

SQL Tutorial
Python Reference

Python Tutorial
W3.CSS Reference

W3.CSS Tutorial
Bootstrap Reference

Bootstrap Tutorial
PHP Reference

PHP Tutorial
HTML Colors

Java Tutorial
Java Reference

C++ Tutorial
Angular Reference

jQuery Tutorial
jQuery Reference

Top Examples Web Courses


HTML Examples
HTML Course

CSS Examples
CSS Course

JavaScript Examples
JavaScript Course

How To Examples
Front End Course

SQL Examples
SQL Course

Python Examples
Python Course

W3.CSS Examples
PHP Course

Bootstrap Examples
jQuery Course

PHP Examples
Java Course

Java Examples
C++ Course

XML Examples
C# Course

jQuery Examples
XML Course

Get Certified »

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning.
Tutorials, references, and examples are
constantly reviewed to avoid errors, but we cannot warrant full correctness of all content.
While using W3Schools, you agree to have read and accepted our
terms of use, cookie and privacy policy.

Copyright 1999-2021 by Refsnes Data. All Rights Reserved.

W3Schools is Powered by W3.CSS.

You might also like