Khóa ngoại Foreign Key trong SQL – vi-magento.com

Trong bài này bạn sẽ được học cách tạo khóa ngoại Foreign Key bằng câu lệnh SQL thể hiện qua các hệ quản trị CSDL như SQL Server, Oracle, MySQL.

Khóa ngoại là những column đặc biệc dùng để thể hiện mối liên kết giữa hai bảng. Bảng A có column khóa ngoại, nó sẽ trỏ đến khóa chính của bảng B thì ta gọi A là bảng con và B là bảng cha.

Giả sử ta có hai bảng như sau:

  • Orders (OrderID. OrderNumber,

    PersonID

    )

  • Persons (PersonID, LastName, FirstName)

Gạch chân là khóa chính và màu đỏ là khóa ngoại. Như vậy bảng Orders là bảng con vì nó có khóa ngoại PersonID trỏ đến khóa chính của bảng cha là bảng Persion. bây giờ ta sẽ học cách tạo khóa ngoại nhé.

1. Tạo Foreign Key trong lệnh CREATE TABLE

Bạn có thể tạo khóa ngoại ngay trong lệnh tạo bảng Create Table, cách làm như sau:

MySQL

1

2

3

4

5

6

7

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:

1

2

3

4

5

CREATE

TABLE

Orders

(

    

OrderID

int

NOT

NULL

PRIMARY

KEY

,

    

OrderNumber

int

NOT

NULL

,

    

PersonID

int

FOREIGN

KEY

REFERENCES

Persons

(

PersonID

)

)

;

Để đặt tên cho khóa ngoại thì ta viết như sau:

MySQL / SQL Server / Oracle / MS Access

1

2

3

4

5

6

7

8

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

)

)

;

Khi có tên thì sau này rất dễ dàng quản lý khóa ngoại, bạn có thể xóa khóa ngoại thông qua tên của nó.

2. Tạo Foreign Key bằng lệnh Alter Table

Lệnh Alter Table cho phép bạn tạo khóa ngoại, lệnh này được dùng sau khi bạn đã tạo bảng.

MySQL / SQL Server / Oracle / MS Access

1

2

ALTER

TABLE

Orders

ADD

FOREIGN

KEY

(

PersonID

)

REFERENCES

Persons

(

PersonID

)

;

Hoặc sử dụng cách sau để đặt tên cho khóa ngoại.

MySQL / SQL Server / Oracle / MS Access:

1

2

3

ALTER

TABLE

Orders

<

br

/

>

ADD

CONSTRAINT

FK_PersonOrder

<

br

/

>

FOREIGN

KEY

(

PersonID

)

REFERENCES

Persons

(

PersonID

)

;

3. Xóa khóa ngoại

Để xóa được khóa ngoại thì bắt buộc bạn phải biết tên của khóa ngoại, vì vậy khuyến khích bạn khi tạo khóa ngoại thì hãy đặt tên cho nó nhé.

Để xóa thì bạn sử dụng đoạn code sau:

MySQL

1

2

ALTER

TABLE

Orders

DROP

FOREIGN

KEY

FK_PersonOrder

;

SQL Server / Oracle / MS Access

1

2

ALTER

TABLE

Orders

DROP

CONSTRAINT

FK_PersonOrder

;

Một số lưu ý khi xóa khóa ngoại:

  • Sau khi xóa xong thì giữa hai bảng sẽ không còn ràng buộc, vì vậy dữ liệu cho column khóa ngoại của bảng con được tự do, không bắt buộc phải nằm trong phạm vi của bảng cha.
  • Phải chắc chắn là tên của khóa ngoại tồn tại, nếu không thì sẽ nhận thông báo lỗi.