定義:主鍵(PRIMARY KEY)”的完整稱呼是“主鍵約束”。MySQL主鍵約束是一個列或者列的組合,其值能唯一地標識表中的每一行。這樣的一列或多列稱為表的主鍵,通過它可以強制表的實體完整性。
主鍵約束字段的選取:
主鍵約束即在表中定義一個主鍵來唯一確定表中每一行數據的標識符。主鍵可以是表中的某一列或者多列的組合,其中由多列組合的主鍵稱為復合主鍵。主鍵應該遵守下面的規則:
- 每個表只能定義一個主鍵。
- 主鍵值必須唯一標識表中的每一行,且不能為 NULL,即表中不可能存在兩行數據有相同的主鍵值。這是唯一性原則。
- 一個列名只能在復合主鍵列表中出現一次。
- 復合主鍵不能包含不必要的多余列。當把復合主鍵的某一列刪除后,如果剩下的列構成的主鍵仍然滿足唯一性原則,那么這個復合主鍵是不正確的。這是最小化原則。
設置主鍵約束:
1、在創建表時設置
1.1 在定義列的同時指定主鍵,語法規則如下:
<字段名> <數據類型> PRIMARY KEY [默認值]
【實例 1】在 test_db 數據庫中創建 tb_emp 3 數據表,其主鍵為 id;
1.2 在定義完所有列之后,指定主鍵的語法格式為:
[CONSTRAINT <約束名>] PRIMARY KEY [字段名]
【實例 2】在 test_db 數據庫中創建 tb_emp 4 數據表,其主鍵為 id
2、在創建表時設置復合主鍵
主鍵由多個字段聯合組成,語法規則如下:
PRIMARY KEY [字段1,字段2,…,字段n]
【實例 3】創建數據表 tb_emp5,假設表中沒有主鍵 id,為了唯一確定一個員工,可以把 name、deptId 聯合起來作為主鍵
3、在修改表時添加主鍵約束
在修改數據表時添加主鍵約束的語法規則為:
ALTER TABLE <數據表名> ADD PRIMARY KEY(<列名>);
查看 tb_emp2 數據表的表結構,如下所示:
【實例 4】修改數據表 tb_emp2,將字段 id 設置為主鍵