Thông tin liên hệ
- 036.686.3943
- admin@nguoicodonvn2008.info
Khóa chính SQL Server là gì? Tạo primary key trong SQL Server như thế nào? Hãy cùng Quantrimang.com tìm hiểu những điều cần biết về khóa chính trong SQL nhé!
Trong SQL Server, khóa chính là nhân tố ràng buộc xác định duy nhất từng hàng trong bảng. Nó đảm bảo tính toàn vẹn của dữ liệu trong bảng.
Muốn xóa khóa chính trong SQL, nhất định bạn phải hiểu rõ về cách sử dụng nó. Về cơ bản, khóa chính SQL là một cột (hoặc kết hợp các cột) xác định duy nhất từng bản ghi trong một bảng database. Khóa chính cũng tăng tốc độ truy cập dữ liệu và được dùng để thiết lập mối quan hệ giữa các bảng.
Giả sử bạn đang phát triển một ứng dụng tên “Hệ thống quản lý khách hàng” để xử lý tất cả dữ liệu khách hàng của khu nghỉ dưỡng chỉ dành cho thành viên. Dữ liệu này có thể bao gồm thông tin cá nhân chi tiết, ID thành viên được phân công và chi tiết khác về quyền thành viên... Trong tất cả các bảng được tạo trong database này, ID thành viên được dùng để phân biệt các khách hàng. Do đó, trường này sẽ là khóa chính.
Dưới đây là biểu đồ của bảng khách hàng chứa chi tiết thông tin cá nhân của khách hàng. Như bạn thấy, khóa chính được xác định trên cột CUST_ID. Dùng khóa chính, bạn có thể truy xuất một bản ghi riêng của khách hàng bất kỳ. Khóa chính có thể được định nghĩa bằng lệnh CREATE TABLE hoặc lệnh ALTER TABLE.
Cú pháp tạo khóa chính bằng lệnh CREATE TABLE
CREATE TABLE ten_bang ( cot1 kieu_du_lieu [ NULL | NOT NULL ] [ PRIMARY KEY ], cot2 kieu_du_lieu [ NULL | NOT NULL ], ... );
hoặc
CREATE TABLE ten_bang ( cot1 kieu_du_lieu [ NULL | NOT NULL ], cot2 kieu_du_lieu [ NULL | NOT NULL ], … CONSTRAINT ten_rang_buoc PRIMARY KEY (cot1, cot2, … cot_n) );
Ví dụ tạo khóa chính bằng lệnh CREATE TABLE
CREATE TABLE nhanvien ( nhanvien_id INT PRIMARY KEY, ho VARCHAR(50) NOT NULL, ten VARCHAR(50), NOT NULL, luong MONEY );
Ở ví dụ này, khóa chính cho bảng nhanvien được tạo thành từ 1 trường là nhanvien_id. Ngoài ra có thể tạo khóa chính như sau:
CREATE TABLE nhanvien ( nhanvien_id INT, ho VARCHAR(50) NOT NULL, ten VARCHAR(50), NOT NULL, luong MONEY CONSTRAINT nhanvien_pk PRIMARY KEY (nhanvien_id) );
Bây giờ là ví dụ tạo khóa chính có nhiều hơn 1 trường trong SQL Server.
CREATE TABLE nhanvien ( ho VARCHAR(50) NOT NULL, ten VARCHAR(50), NOT NULL, luong MONEY CONSTRAINT nhanvien_pk PRIMARY KEY (ho, ten) );
Ở ví dụ này, chúng ta đã tạo khóa chính tạo thành từ 2 cột là ho và ten. 2 trường này sẽ xác định một cách duy nhất cho bản ghi trong bảng nhanvien.
Chỉ có thể tạo khóa chính bằng lệnh ALTER TABLE ở các cột đã được định nghĩa là NOT NULL. Nếu cột cho phép giá trị NULL, sẽ không thể thêm khóa chính nếu không xóa hoặc tạo lại bảng.
Cú pháp tạo khóa chính bằng lệnh ALTER TABLE
ALTER TABLE ten_bang ADD CONSTRAINT ten_rang_buoc PRIMARY KEY (cot1, cot2, … cot_n);
Ví dụ tạo khóa chính bằng lệnh ALTER TABLE
ALTER TABLE nhanvien ADD CONSTRAINT nhanvien_pk PRIMARY KEY (nhanvien_id);
Trong ví dụ này, ta tạo khóa chính nhanvien_pk cho bảng nhanvien có sẵn, gồm trường nhanvien_id. Lưu ý là trường nhanvien_id phải được định nghĩa là NOT NULL trước đó, nếu không sẽ phải xóa và tạo lại bảng và định nghĩa trường này là NOT NULL.
Có thể tạo khóa chính với nhiều hơn 1 trường như trong ví dụ sau.
ALTER TABLE nhanvien ADD CONSTRAINT nhanvien_pk PRIMARY KEY (ho, ten);
Khóa chính cho bảng nhanvien gồm 2 trường là họ và tên. Cả 2 phải được định nghĩa là NOT NULL.
Cú pháp xóa khóa chính bằng lệnh ALTER TABLE
ALTER TABLE ten_bang DROP CONSTRAINT ten_rang_buoc;
Ví dụ xóa khóa chính bằng lệnh ALTER TABLE
ALTER TABLE nhanvien DROP CONSTRAINT nhanvien_pk;
Ví dụ trên xóa khóa chính nhanvien_pk trong bảng nhanvien.
Cú pháp vô hiệu hóa khóa chính bằng lệnh ALTER INDEX
ALTER INDEX ten_rang_buoc ON ten_bang DISABLE;
Ví dụ vô hiệu hóa khóa chính bằng lệnh ALTER INDEX
ALTER INDEX nhanvien_pk ON nhanvien DISABLE;
Ví dụ trên vô hiệu hóa khóa chính nhanvien_pk trong bảng nhanvien.
Cú pháp kích hoạt khóa chính bằng lệnh ALTER INDEX
ALTER INDEX ten_rang_buoc ON ten_bang REBUILD;
Ví dụ kích hoạt khóa chính bằng lệnh ALTER INDEX
ALTER INDEX nhanvien_pk ON nhanvien REBUILD;
Ví dụ trên kích hoạt lại khóa chính nhanvien_pk của bảng nhanvien.
Lệnh SQL sau tạo một khóa chính trên cột “S_Id” khi bảng Sinh viên (Students) được tạo.
CREATE TABLE students ( S_Id int NOT NULL PRIMARY KEY, LastName varchar (255) NOT NULL, FirstName varchar (255), Address varchar (255), City varchar (255), )
Tạo khóa chính trong SQL cho nhiều cột:
CREATE TABLE students ( S_Id int NOT NULL, LastName varchar (255) NOT NULL, FirstName varchar (255), Address varchar (255), City varchar (255), CONSTRAINT pk_StudentID PRIMARY KEY (S_Id, LastName) )
Ở ví dụ trên chỉ có một khóa chính (pk_StudentID). Tuy nhiên, nó tạo thành hai cột (S_Id và LastName).
Tóm lại, những điều cần nhớ về khóa chính trong SQL Server:
Lưu ý: Khi xác định một ràng buộc khóa chính cho một bảng, công cụ database tự động tạo một index riêng cho cột khóa chính.
Ưu điểm của tạo khóa chính SQL Server: Ưu điểm chính nổi bật nhất là giúp người dùng truy cập nhanh.
Nguồn tin: Quantrimang.com:
Ý kiến bạn đọc
Những tin mới hơn
Những tin cũ hơn
Cách thiết lập các trang web yêu thích trong Google AI Overviews và AI Mode
Những lời chúc đầu tuần hay cho cả 7 ngày may mắn
OmniVoice Studio: Giải pháp Voice AI mã nguồn mở đáng trải nghiệm
Xây dựng hệ thống social media hoàn chỉnh với AI
AI: Người đồng hành phát triển web không thể thiếu của bạn
Prompt tạo infographic kiến trúc nhà ở cao cấp cực kỳ ấn tượng bằng AI
Cấu trúc HTML với AI
Cách tạo ảnh AI trên Microsoft AI Playground
Kiến thức cơ bản về JavaScript với AI
Prompt tạo infographic sản phẩm với 7 góc nhìn chuyên nghiệp bằng AI
Cách tạo mô hình 3D trên Canva bằng AI
Cách biến ảnh thật thành nghệ thuật cắt giấy 3D nhiều lớp bằng AI
Prompt tạo ảnh chân dung nghệ thuật đen trắng cực chất bằng AI
Viết bài đăng mạng xã hội thu hút sự chú ý với sự hỗ trợ của AI
Cách chuyển ghi chú viết tay thành infographic
20+ câu lệnh AI biến ảnh gốc thành nghệ thuật cắt giấy 3D nhiều lớp
Lên lịch và tạo hàng loạt bài đăng với sự trợ giúp của AI
Hướng dẫn xóa logo trong video bằng CapCut
Gắn kết và xây dựng cộng đồng trên mạng xã hội với AI