Cách tạo khóa ngoại trong phpmyadmin

Chúng ta đã được học các lệnh tạo bảng (Create Table), khái niệm về khóa chính (Primary Key) và một vài thành phần khác như UNIQUE, AUTO_INCREMENT, mặc khác tất cả các thành phần này đều xử lý trên một bảng duy nhất. Câu hỏi đặt ra là nếu có nhiều bảng thì liệu có mối LH giữa chúng hay không? Câu trả lời là có, và đó chính là khóa ngoại foreign key.

Mục lục bài viết

1. Khóa ngoại (Foreign Key) là gì?

Trong bài này tôi sẽ không trình bài khái niệm khóa ngoại một cách chi tiết nữa mà đi vào định nghĩa chính của nó. Foreign key là mối quan hệ giữa hai bảng và mối quan hệ này ta hay gọi là cha – con, nghĩa là nếu bảng A có một thuộc tính kết nối tới bảng B thì lúc này bảng B đóng vai trò là cha và bảng A đóng vai trò là con.

Bạn đang xem: foreign key la gi

Khái niệm Foreign key là gì không những có ở MySQL mà nó là một thành phần của tất cả các hệ quản trị CSDL như SQL Server, Oracle, Access, … Nếu bạn đã từng học qua các mô hình CSLD thì không còn lạ gì khóa ngoại nữa.

Thông thường chúng ta có hai loại khóa ngoại đó là khóa ngoại giữa hai bảng và khóa ngoại trỏ đến chính nó (đệ quy).

Nhiều Bạn Cũng Xem  Chi Phí Sản Xuất Chung Là Gì ? Chi Phí Sản Xuất Chung Bao Gồm Những Chi Phí Gì

Khóa ngoại giữa hai bảng

Tham khảo thêm: Đánh giá về jd la gi | Sen Tây Hồ

Xét sơ đồ CSDL sau đây:

Cách tạo khóa ngoại trong phpmyadmin

Các bạn thấy trong bảng customers và orders có một mối quan hệ với tên gọi là “mỗi order là của một customer nào đó“. đây ta gọi là mối quan hệ (1:n), có nghĩa là một customer có thê có nhiều orders và mỗi order chỉ thuộc về một customer duy nhất. Xem kỹ hơn ta thấy trong bảng orders có field customerNumber và nó sẽ trỏ đến khóa chính (Primary Key) của bảng customers.

Như vậy ta có kế luận như sau:

Khóa ngoại ở bảng orders sẽ tham chiếu đến khóa chính của bảng customers. Lúc này bảng customers gọi là bảng cha và bảng order gọi là bảng con. Đây chính là điều BẮT BUỘC của khóa ngoại.

Khóa ngoại trỏ đến chính bảng đó

Tham khảo thêm: Đánh giá về jd la gi | Sen Tây Hồ

Xét sơ đồ CSDL sau đây:

Cách tạo khóa ngoại trong phpmyadmin

Trong sơ đồ này nó có một khóa ngoại là reportsTo và trỏ đến chính khóa chính của nó employeeNumber. Mối quan hệ này ta nói như sau “mỗi nhân viên khả năng là một nhân viên bình thường hoặc là người quản lý của một nhân viên khác. Hằng ngày các nhân bị quản lý khác sẽ báo cáo (reportsTo) tới nhân viên quản lý”. Sơ đồ này ta gọi là đệ quy, nghĩa là khóa ngoại sẽ tham chiếu tới chính table nó luôn. Trong thực tế cũng hay gặp trường hợp này nên các bạn cần lưu ý nha.

2. Tạo khóa ngoại (Foreign Key) trong MySQL

Ta sẽ dùng cú pháp T-SQL để tạo khóa ngoại, chúng ta có khá nhiều các tạo và tùy vào mong muốn của ban mà dùng cho phù hợp. Tất cả các cách đều có chung một cấu trúc đó là khai báo field của bảng A và sẽ tham chiếu đến field nào của bảng B bởi từ khóa REFERENCES.

Nhiều Bạn Cũng Xem  Correlation Là Gì – Lý Thuyết Hệ Số Tương Quan Pearson

Tạo trong lệnh tạo bảng create table

Chúng ta sẽ tạo trực tiếp trong lệnh tạo bảng và cú pháp của nó cũng tương tự như lệnh tạo khóa chính, nghĩa là sẽ đặt ở cuối phần khai báo field. Nếu dùng cách này thì khóa ngoại sẽ không có tên.

Các bạn thấy tôi đã dùng từ khóa FOREIGN KEY (groupid) REFERENCES Groups(groupid) để tạo khóa ngoại, trong đó:

  • FOREIGN KEY (groupid): là field được chọn làm khóa ngoại ở bảng con, tức là bảng Users.
  • REFERENCES Groups(groupid): là khóa chính của bảng cha, tức là bảng Groups.

Sau khi tạo xong bạn vào PHPMyAdmin và chọn mục database, chọn diagram ở thanh công cụ thì lúc này bạn sẽ thấy một sơ đồ như sau:

Cách tạo khóa ngoại trong phpmyadmin

Như vậy là bạn đã tạo thành công rồi đấy.

Ví dụ có đặt tên:

Xem thêm: Mạng xã hội Hahalolo là gì? Tất tần tật những điều cần biết về Hahalolo | Tin Tức Hahalolo

Tương tự như các phần trước, để đặt tên cho khóa ngoại thì ta phải dùng từ khóa CONSTRAINT.

Tạo bằng lệnh ALTER TABLE

Với cách này ta phải tạo hai bảng trước, sau đó sẽ dùng lệnh ALTER TABLE để thêm FOREIGN KEY.

Hoặc:

Tạo khóa ngoại trường hợp tham chiếu chính nó

Trường hợp này ta cũng dùng cú pháp tương tự, thay vì tham chiếu tới bảng nào đó thì sẽ tham chiếu đến chính nó.

3. Xóa (Drop) Foreign Key

Để xóa được Foreign Key thì bạn phải biết tên của nó là gì, mà tên chỉ tồn tại trong trường hợp ta có dùng từ khóa CONSTRAINT lúc tạo khóa, vì thế khuyến khích bạn dùng CONSTRAINT để tạo khóa ngoại.

Sau đây là cú pháp xóa Foreign Key:

Trong đó fk_group là tên của khóa ngoại.

Lưu ý quan trọng:

Bạn chỉ thực hiện được thao tác xóa khi không tồn tại một bảng con nào tham chiếu đến nó.

4. Lời kết

Trong bài này chủ yếu tìm hiểu định nghĩa của khóa ngoại (Foreign key) và tìm hiểu một vài cách tạo khóa ngoại thông dụng, bài này kết thúc tại đây, bài tiếp theo mình sẽ nói về lệnh alter table.

Nhiều Bạn Cũng Xem  BẠN BẤT NGỜ ĐẾN CHƠI, ĂN BÚN CHẢ GIÒ TÔM CUA,BÁNH LÁ GAI

Xem thêm: Hướng dẫn cách điền First name, Last name và Middle name

Bạn thấy bài viết thế nào?

Các câu hỏi về Khóa ngoại (Foreign Key) trong MySQL

Team ASIANA mà chi tiết là Ý Nhi đã biên soạn bài viết dựa trên tư liệu sẵn có và kiến thức từ Internet. Dĩ nhiên tụi mình biết có nhiều câu hỏi và nội dung chưa thỏa mãn được bắt buộc của các bạn.

Thế nhưng với tinh thần tiếp thu và nâng cao hơn, Mình luôn đón nhận tất cả các ý kiến khen chê từ các bạn & Quý đọc giả cho bài viêt Khóa ngoại (Foreign Key) trong MySQL

Nếu có bắt kỳ câu hỏi thắc mắt nào vê Khóa ngoại (Foreign Key) trong MySQL hãy cho chúng mình biết nha, mõi thắt mắt hay góp ý của các bạn sẽ giúp mình nâng cao hơn hơn trong các bài sau nha

Các Hình Ảnh Về Khóa ngoại (Foreign Key) trong MySQL

Cách tạo khóa ngoại trong phpmyadmin

Các từ khóa tìm kiếm cho bài viết #Khóa #ngoại #Foreign #Key #trong #MySQL

Tham khảo thêm dữ liệu, về Khóa ngoại (Foreign Key) trong MySQL tại WikiPedia

Bạn khả năng xem nội dung chi tiết về Khóa ngoại (Foreign Key) trong MySQL từ trang Wikipedia.◄

Tham Gia Cộng Đồng Tại

💝 Nguồn Tin tại: https://hubm.edu.vn

💝 Xem Thêm Giải Đáp Thắc Mắt tại : https://hubm.edu.vn/la-gi/

Thông tin cần xem thêm: Khóa ngoại (Foreign Key) trong MySQL

Hình Ảnh về Khóa ngoại (Foreign Key) trong MySQL

Video về Khóa ngoại (Foreign Key) trong MySQL

Wiki về Khóa ngoại (Foreign Key) trong MySQL

Khóa ngoại (Foreign Key) trong MySQL


Khóa ngoại (Foreign Key) trong MySQL -

Bài viết Khóa ngoại (Foreign Key) trong MySQL thuộc chủ đề về Giải Đáp Câu Hỏi đang được rất nhiều bạn quan tâm đúng không nào !! Hôm nay, Hãy cùng https://hubm.edu.vn/ tìm hiểu Khóa ngoại (Foreign Key) trong MySQL trong bài viết hôm nay nha !
Các bạn đang xem chủ đề về : “Khóa ngoại (Foreign Key) trong MySQL”

Chúng ta đã được học các lệnh tạo bảng (Create Table), khái niệm về khóa chính (Primary Key) và một vài thành phần khác như UNIQUE, AUTO_INCREMENT, mặc khác tất cả các thành phần này đều xử lý trên một bảng duy nhất. Câu hỏi đặt ra là nếu có nhiều bảng thì liệu có mối LH giữa chúng hay không? Câu trả lời là có, và đó chính là khóa ngoại foreign key.

1. Khóa ngoại (Foreign Key) là gì?

Trong bài này tôi sẽ không trình bài khái niệm khóa ngoại một cách chi tiết nữa mà đi vào định nghĩa chính của nó. Foreign key là mối quan hệ giữa hai bảng và mối quan hệ này ta hay gọi là cha – con, nghĩa là nếu bảng A có một thuộc tính kết nối tới bảng B thì lúc này bảng B đóng vai trò là cha và bảng A đóng vai trò là con.

Bạn đang xem: foreign key la gi

Khái niệm Foreign key là gì không những có ở MySQL mà nó là một thành phần của tất cả các hệ quản trị CSDL như SQL Server, Oracle, Access, … Nếu bạn đã từng học qua các mô hình CSLD thì không còn lạ gì khóa ngoại nữa.

Thông thường chúng ta có hai loại khóa ngoại đó là khóa ngoại giữa hai bảng và khóa ngoại trỏ đến chính nó (đệ quy).

Nhiều Bạn Cũng Xem  Chi Phí Sản Xuất Chung Là Gì ? Chi Phí Sản Xuất Chung Bao Gồm Những Chi Phí Gì

Khóa ngoại giữa hai bảng

Tham khảo thêm: Đánh giá về jd la gi | Sen Tây Hồ

Xét sơ đồ CSDL sau đây:

Cách tạo khóa ngoại trong phpmyadmin

Các bạn thấy trong bảng customers và orders có một mối quan hệ với tên gọi là “mỗi order là của một customer nào đó“. đây ta gọi là mối quan hệ (1:n), có nghĩa là một customer có thê có nhiều orders và mỗi order chỉ thuộc về một customer duy nhất. Xem kỹ hơn ta thấy trong bảng orders có field customerNumber và nó sẽ trỏ đến khóa chính (Primary Key) của bảng customers.

Như vậy ta có kế luận như sau:

Khóa ngoại ở bảng orders sẽ tham chiếu đến khóa chính của bảng customers. Lúc này bảng customers gọi là bảng cha và bảng order gọi là bảng con. Đây chính là điều BẮT BUỘC của khóa ngoại.

Khóa ngoại trỏ đến chính bảng đó

Tham khảo thêm: Đánh giá về jd la gi | Sen Tây Hồ

Xét sơ đồ CSDL sau đây:

Cách tạo khóa ngoại trong phpmyadmin

Trong sơ đồ này nó có một khóa ngoại là reportsTo và trỏ đến chính khóa chính của nó employeeNumber. Mối quan hệ này ta nói như sau “mỗi nhân viên khả năng là một nhân viên bình thường hoặc là người quản lý của một nhân viên khác. Hằng ngày các nhân bị quản lý khác sẽ báo cáo (reportsTo) tới nhân viên quản lý”. Sơ đồ này ta gọi là đệ quy, nghĩa là khóa ngoại sẽ tham chiếu tới chính table nó luôn. Trong thực tế cũng hay gặp trường hợp này nên các bạn cần lưu ý nha.

2. Tạo khóa ngoại (Foreign Key) trong MySQL

Ta sẽ dùng cú pháp T-SQL để tạo khóa ngoại, chúng ta có khá nhiều các tạo và tùy vào mong muốn của ban mà dùng cho phù hợp. Tất cả các cách đều có chung một cấu trúc đó là khai báo field của bảng A và sẽ tham chiếu đến field nào của bảng B bởi từ khóa REFERENCES.

Nhiều Bạn Cũng Xem  Correlation Là Gì - Lý Thuyết Hệ Số Tương Quan Pearson

Tạo trong lệnh tạo bảng create table

Chúng ta sẽ tạo trực tiếp trong lệnh tạo bảng và cú pháp của nó cũng tương tự như lệnh tạo khóa chính, nghĩa là sẽ đặt ở cuối phần khai báo field. Nếu dùng cách này thì khóa ngoại sẽ không có tên.

Các bạn thấy tôi đã dùng từ khóa FOREIGN KEY (groupid) REFERENCES Groups(groupid) để tạo khóa ngoại, trong đó:

  • FOREIGN KEY (groupid): là field được chọn làm khóa ngoại ở bảng con, tức là bảng Users.
  • REFERENCES Groups(groupid): là khóa chính của bảng cha, tức là bảng Groups.

Sau khi tạo xong bạn vào PHPMyAdmin và chọn mục database, chọn diagram ở thanh công cụ thì lúc này bạn sẽ thấy một sơ đồ như sau:

Cách tạo khóa ngoại trong phpmyadmin

Như vậy là bạn đã tạo thành công rồi đấy.

Ví dụ có đặt tên:

Xem thêm: Mạng xã hội Hahalolo là gì? Tất tần tật những điều cần biết về Hahalolo | Tin Tức Hahalolo

Tương tự như các phần trước, để đặt tên cho khóa ngoại thì ta phải dùng từ khóa CONSTRAINT.

Tạo bằng lệnh ALTER TABLE

Với cách này ta phải tạo hai bảng trước, sau đó sẽ dùng lệnh ALTER TABLE để thêm FOREIGN KEY.

Hoặc:

Tạo khóa ngoại trường hợp tham chiếu chính nó

Trường hợp này ta cũng dùng cú pháp tương tự, thay vì tham chiếu tới bảng nào đó thì sẽ tham chiếu đến chính nó.

3. Xóa (Drop) Foreign Key

Để xóa được Foreign Key thì bạn phải biết tên của nó là gì, mà tên chỉ tồn tại trong trường hợp ta có dùng từ khóa CONSTRAINT lúc tạo khóa, vì thế khuyến khích bạn dùng CONSTRAINT để tạo khóa ngoại.

Sau đây là cú pháp xóa Foreign Key:

Trong đó fk_group là tên của khóa ngoại.

Lưu ý quan trọng:

Bạn chỉ thực hiện được thao tác xóa khi không tồn tại một bảng con nào tham chiếu đến nó.

4. Lời kết

Trong bài này chủ yếu tìm hiểu định nghĩa của khóa ngoại (Foreign key) và tìm hiểu một vài cách tạo khóa ngoại thông dụng, bài này kết thúc tại đây, bài tiếp theo mình sẽ nói về lệnh alter table.

Nhiều Bạn Cũng Xem  BẠN BẤT NGỜ ĐẾN CHƠI, ĂN BÚN CHẢ GIÒ TÔM CUA,BÁNH LÁ GAI

Xem thêm: Hướng dẫn cách điền First name, Last name và Middle name

Bạn thấy bài viết thế nào?

Các câu hỏi về Khóa ngoại (Foreign Key) trong MySQL

Team ASIANA mà chi tiết là Ý Nhi đã biên soạn bài viết dựa trên tư liệu sẵn có và kiến thức từ Internet. Dĩ nhiên tụi mình biết có nhiều câu hỏi và nội dung chưa thỏa mãn được bắt buộc của các bạn.

Thế nhưng với tinh thần tiếp thu và nâng cao hơn, Mình luôn đón nhận tất cả các ý kiến khen chê từ các bạn & Quý đọc giả cho bài viêt Khóa ngoại (Foreign Key) trong MySQL

Nếu có bắt kỳ câu hỏi thắc mắt nào vê Khóa ngoại (Foreign Key) trong MySQL hãy cho chúng mình biết nha, mõi thắt mắt hay góp ý của các bạn sẽ giúp mình nâng cao hơn hơn trong các bài sau nha

Các Hình Ảnh Về Khóa ngoại (Foreign Key) trong MySQL

Cách tạo khóa ngoại trong phpmyadmin

Các từ khóa tìm kiếm cho bài viết #Khóa #ngoại #Foreign #Key #trong #MySQL

Tham khảo thêm dữ liệu, về Khóa ngoại (Foreign Key) trong MySQL tại WikiPedia

Bạn khả năng xem nội dung chi tiết về Khóa ngoại (Foreign Key) trong MySQL từ trang Wikipedia.◄

Tham Gia Cộng Đồng Tại

💝 Nguồn Tin tại: https://hubm.edu.vn

💝 Xem Thêm Giải Đáp Thắc Mắt tại : https://hubm.edu.vn/la-gi/

[rule_{ruleNumber}]

Bạn thấy bài viết Khóa ngoại (Foreign Key) trong MySQL có giải quyết đươc vấn đề bạn tìm hiểu không?, nếu  không hãy comment góp ý thêm về Khóa ngoại (Foreign Key) trong MySQL bên dưới để https://hubm.edu.vn/ có thể chỉnh sửa & cải thiện nội dung tốt hơn cho độc giả nhé! Cám ơn bạn đã ghé thăm Website ĐH KD & CN Hà Nội