Cách Tạo Khóa Ngoại Trong Sql Server, Khác Biệt Giữa Khóa Chính Và Khóa Ngoại Trong Sql

Các khoá chính và khóa ngoại là hai loại ràng buộc có thể được sử dụng để thực thi toàn vẹn dữ liệu trong các bảng SQL Server và đây là những đối tượng cơ sở dữ liệu quan trọng.Bạn đang xem : Cách tạo khóa ngoại trong sql

Trong SQL Server, có hai khóa – khóa chính và khoá ngoại có vẻ như giống nhau, nhưng thực tiễn cả hai đều khác nhau về các tính năng và hành vi. Các khoá chính và khóa ngoại là hai loại ràng buộc hoàn toàn có thể được sử dụng để thực thi toàn vẹn tài liệu trong các bảng SQL Server và đây là những đối tượng người tiêu dùng cơ sở tài liệu quan trọng .

Trong bài này, tôi muốn chia sẻ sự khác biệt chính giữa khóa chính và khoá ngoại.

1. Khóa chính là gì

Khóa chính ( hay ràng buộc khóa chính ) được sử dụng để định danh duy nhất mỗi record trong table của cơ sở tài liệu .Ngoài ra, nó còn dùng để thiết lập quan hệ 1 – n ( hay ràng buộc tham chiếu ) giữa hai table trong cơ sở tài liệu .Dữ liệu ( value ) của field khóa chính phải có tính duy nhất. Và không chứa các giá trị Null .Mỗi table nên chỉ có một khóa chính, khóa chính hoàn toàn có thể tạo ra từ nhiều field của table .

2. Khóa ngoại là gì

Khóa ngoại của một table được xem như con trỏ trỏ tới khóa chính của table khác .Nếu trường MaSV của table DiemSV được sử dụng để tạo ràng buộc tham chiếu đến table HSSV, trải qua khóa chính là MaSV thì MaSV của table DiemSV được gọi là khóa ngoại của bảng này. Đây cũng chính là nguyên do mà ta nói, khóa ngoại được xem như con trỏ trởi tới khóa chính .Để hiểu rõ hơn về ý nghĩa sử dụng của khóa chính, khóa ngoại tất cả chúng ta hãy xét ví dụ sau : Giả sử cơ sở tài liệu QLDiemSV có hai table : HSSV và DiemSV như sau :Table HSSV gồm 6 field, trong đó MaSV được chọn làm khóa chính của table này .*Table DiemSV gồm 6 field, trong đó STT là khóa chính và MaSV được chọn làm khóa ngoại của table này .*Như vậy, hai table HSSV và DiemSV quan hệ tài liệu với nhau trải qua field MaSV của mỗi table ( đây là quan hệ 1 – n ). Hay nói cách khác, ràng buộc tham chiếu đã được tạo giữa hai table ( từ table DiemSV đến table HSSV ) .Với ràng buộc này thì, việc người sử dụng vô tình hay cố ý tàn phá các link sẽ bị ngăn ngừa. Và, người sử dụng cũng không hề nhập vào cột khóa ngoại một giá trị mà giá trị đó không Open ở cột khóa chính mà khóa này trỏ tới ( không hề nhập điểm cho một sinh viên, vào table DiemSV, mà mã của họ không Open ở cột MaSV ở table HSSV ) .

3. Thiết lập khóa chính

Để tạo khóa chính ngay trong khi tạo table ta hoàn toàn có thể sử dụng câu lệnh SQL Create Table như sau 🙁 MaSV varchar ( 8 ) NOT NULL, Holot varchar ( 20 ), Ten varchar ( 8 ), NgaySinh Date, MaLop varchar ( 8 ) NOT NULL, Lienhe varchar ( 11 ) NOT NULL, PRIMARY KEY ( MaSV ) ) ; Câu lệnh này dùng để tạo table HSSV, đồng thời chỉ định field MaSV làm khóa chính cho nó .Trong trường hợp khóa chính được xây dựng từ nhiều field và ta cần đặt tên cho ràng buộc khóa này thì hoàn toàn có thể sử dụng câu lệnh Create Table như sau 🙁 MaSV varchar ( 8 ) NOT NULL, Holot varchar ( 20 ), Ten varchar ( 8 ), NgaySinh DATE, MaLop varchar ( 8 ) NOT NULL, Lienhe varchar ( 11 ) NOT NULL, CONSTRAINT Ma PRIMARY KEY ( MaSV, MaLop ) ) ; Vậy khóa chính table này được xây dựng từ hai field : MaSV và MaLop và tên của ràng buộc này là Ma .Xem thêm : Bình Ắc Quy Tốt Nhất Hiện Nay ? Phương Pháp So Sánh Loại Ắc Quy Nào Tốt Nhất3.1 Tạo khóa chính cho table đã tạo3.1 Tạo khóa chính cho table đã tạoSử dụng câu lệnh sau :

ALTER TABLE HSSV ADD PRIMARY KEY (MaSV)

Hoặc :ALTER TABLE HSSV ADD CONSTRAINT Ma PRIMARY KEY ( MaSV, MaLop )Rõ ràng, trong trường hợp này các field MaSV, MaLop phải đã được khai báo ràng buộc NOT NULL ( trng khi tạo table ) .3.2 Xóa khóa chính3.2 Xóa khóa chínhSử dụng câu lệnh sau :ALTER TABLE HSSV DROP PRIMARY KEY ;Hoặc :ALTER TABLE HSSV DROP CONSTRAINT Ma

4. Thiết lập khóa ngoại

Để tạo khóa ngoại ngay trong khi tạo table ta hoàn toàn có thể sử dụng câu lệnh SQL Create Table như sau 🙁 STT INT NOT NULL AUTO_INCREMENT, MaSV varchar ( 8 ) NOT NULL, MonHoc varchar ( 6 ) NOT NULL, HKI, HKII, ĐTB_Nam INT, PRIMARY KEY ( STT ), FOREIGN KEY ( MaSV ) REFERENCES HSSV ( MaSV ) ) Câu lệnh này : Tạo table DiemSV gồm 6 field, trong đó khóa chính là field STT và field khóa ngoại là MaSV. Table này tạo ràng buộc tham chiếu đến table HSSV trải qua field MaSV .Dạng khác 🙁 STT INT NOT NULL AUTO_INCREMENT, MaSV varchar ( 8 ) NOT NULL, MonHoc varchar ( 6 ) NOT NULL, HKI, HKII, ĐTB_Nam INT, PRIMARY KEY ( STT ), CONSTRAINT Ma FOREIGN KEY ( MaSV ) REFERENCES HSSV ( MaSV ) ) Khi cần đặt tên cho ràng buộc khóa ngoại và khóa ngoại được hình thành từ nhiều field thì ta phải sử dụng câu lệnh Create Table theo dạng này .4.1 Tạo khóa ngoại cho table đã tạo4.1 Tạo khóa ngoại cho table đã tạoVí dụ :REFERENCES HSSV ( MaSV ) Hoặc :FOREIGN KEY ( MaSV ) REFERENCES HSSV ( MaSV ) Câu lệnh này được sử dụng trong trường hợp cần đặt tên cho ràng buộc khóa ngoại và khóa ngoại được hình thành từ nhiều field .4.2 Xóa khóa ngoại4.2 Xóa khóa ngoạiVí dụ :ALTER TABLE DiemSV DROP FOREIGN KEY Ma

Câu lệnh MySQL ALTER được sử dụng rất phổ biến trong các trường hợp thay đổi tên của table, tên của field hoặc thêm/xóa các field trong một table nào đó. Vì vậy, chúng ta sẽ trở lại câu lệnh này ở các bài sau.

5. Bảng so sánh

Khóa chínhKhóa ngoại
Khóa chính xác định duy nhất một bản ghi trong bảng. Khóa ngoại là một trường trong bảng và là khóa chính trong một bảng khác.
Khóa chính không chấp nhận các giá trị rỗng. Khóa ngoại có thể chấp nhận nhiều giá trị rỗng.
Theo mặc định, khoá chính là chỉ mục được nhóm và dữ liệu trong bảng cơ sở dữ liệu được tổ chức theo thứ tự của dãy chỉ mục nhóm. Khóa ngoại không tự động tạo ra một chỉ mục, nhóm hoặc không nhóm. Bạn có thể tự tạo một chỉ mục trên khoá ngoại.
Chúng ta chỉ có thể có một khóa chính trong một bảng. Chúng ta có thể có nhiều khoá ngoại trong một bảng.

6. Tổng kết

Chúng ta chỉ sử dụng các cách trên để tạo khóa chính trong MySQL và không chỉ có ở MySQL mà ở SQL Server cũng có cú pháp tương tự như vì chúng đều sử dụng ngôn từ T-SQL .Xem thêm : Cách Fix Lỗi * 101 # Ios 8.4, Hướng Dẫn Chi Tiết Cách Fix Lỗi * 101 # Ios 8Thông thường khi thao tác với các ứng dụng web thì ta ít khi sử dụng khóa ngoại chính bới sẽ rất chậm, thế cho nên người ta sẽ cố gắng nỗ lực phong cách thiết kế CSDL làm thế nào tối ưu để không sống sót khóa ngoại .