在mysql中,主鍵全名為“主鍵約束”,是一個列或多個列的組合,其值能唯一地標識表中的每一行,透過它可強製表的實體完整性;主鍵的作用是確定該資料的唯一性,主要是用於和其他表的外鍵關聯,以及本記錄的修改與刪除。
本教學操作環境:windows7系統、mysql8版本、Dell G3電腦。
mysql 主鍵是什麼?
主鍵(PRIMARY KEY),也稱為「主鍵約束」。
MySQL主鍵約束是一個欄位或多個欄位的組合,其值能唯一地識別表中的每一行。這樣的一列或多列稱為表的主鍵,透過它可以強製表的實體完整性。主鍵主要是用於其他表的外鍵關聯,以及本記錄的修改與刪除。
主鍵(PRIMARY KEY)是 MySQL 中使用最頻繁的限制。一般情況下,為了方便 DBMS 更快的查找到表中的記錄,都會在表中設定一個主鍵。
使用主鍵應注意以下幾點:
每個表只能定義一個主鍵。
主鍵值必須唯一標識表中的每一行,且不能為 NULL,即表中不可能存在具有相同主鍵值的兩行資料。這是唯一性原則。
一個欄位名稱只能在聯合主鍵欄位表中出現一次。
聯合主鍵不能包含不必要的多餘欄位。當刪除聯合主鍵的某一欄位後,如果剩下的欄位所構成的主鍵仍然滿足唯一性原則,那麼這個聯合主鍵是不正確的。這是最小化原則。
在建立表格時設定主鍵約束
在建立資料表時設定主鍵約束,既可以為表中的一個欄位設定主鍵,也可以為表中多個欄位設定聯合主鍵。但是不論使用哪一種方法,在一個表中主鍵只能有一個。以下分別講解設定單字段主鍵和多字段聯合主鍵的方法。
1)設定單一欄位主鍵
在 CREATE TABLE 語句中,透過 PRIMARY KEY 關鍵字來指定主鍵。
在定義欄位的同時指定主鍵,語法格式如下:
<字段名> <数据类型> PRIMARY KEY [默认值]
範例1
在test_db 資料庫中建立tb_emp3 資料表,其主鍵為id,SQL 語句和運行結果如下。
mysql> CREATE TABLE tb_emp3 -> ( -> id INT(11) PRIMARY KEY, -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp3; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(25) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.14 sec)
或是在定義完所有欄位之後指定主鍵,語法格式如下:
[CONSTRAINT <约束名>] PRIMARY KEY [字段名]
範例2
在test_db 資料庫中建立tb_emp4 資料表,其主鍵為id ,SQL 語句和運行結果如下。
mysql> CREATE TABLE tb_emp4 -> ( -> id INT(11), -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT, -> PRIMARY KEY(id) -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp4; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(25) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.14 sec)
2)在建立表格時設定聯合主鍵
所謂的聯合主鍵,就是這個主鍵是由一張表中多個欄位組成的。
例如,設定學生選課資料表時,使用學生編號做主鍵還是用課程編號做主鍵呢?如果用學生編號做主鍵,那麼一個學生就只能選擇一門課程。如果用課程編號做主鍵,那麼一門課程只能有一個學生來選。顯然,這兩種情況都是不符合實際情況的。
實際上設計學生選課表,要限定的是一位學生只能選擇同一課程一次。因此,學生編號和課程編號可以放在一起共同作為主鍵,也就是聯合主鍵了。
主鍵由多個欄位聯合組成,語法格式如下:
PRIMARY KEY [字段1,字段2,…,字段n]
注意:當主鍵是由多個欄位組成時,不能直接在欄位名稱後面宣告主鍵約束。
例 3
建立資料表 tb_emp5,假設表中沒有主鍵 id,為了唯一確定一個員工,可以把 name、deptId 聯合起來作為主鍵,SQL 語句和運行結果如下。
mysql> CREATE TABLE tb_emp5 -> ( -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT, -> PRIMARY KEY(name,deptId) -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp5; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | name | varchar(25) | NO | PRI | NULL | | | deptId | int(11) | NO | PRI | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 3 rows in set (0.14 sec)
在修改表時新增主鍵約束
主鍵約束不僅可以在建立表的同時創建,也可以在修改表時添加。但是要注意的是,設定成主鍵約束的欄位中不允許有空值。
在修改資料表時新增主鍵約束的語法格式如下:
ALTER TABLE <数据表名> ADD PRIMARY KEY(<字段名>);
檢視 tb_emp2 資料表的表結構,SQL 語句和執行結果如下所示。
mysql> DESC tb_emp2; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | | NULL | | | name | varchar(30) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.14 sec)
範例 4
修改資料表 tb_emp2,將欄位 id 設為主鍵,SQL 語句和執行結果如下。
mysql> ALTER TABLE tb_emp2 -> ADD PRIMARY KEY(id); Query OK, 0 rows affected (0.94 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC tb_emp2; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(30) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.12 sec)
通常情況下,當在修改表時要設定表中某個欄位的主鍵約束時,要確保設定成主鍵約束的欄位中值不能夠有重複的,並且要保證是非空的。否則,無法設定主鍵約束。
刪除主鍵約束
當一個表中不需要主鍵約束時,就需要從表中刪除。刪除主鍵約束的方法比建立主鍵約束容易的多。
刪除主鍵約束的語法格式如下所示:
ALTER TABLE <数据表名> DROP PRIMARY KEY;
範例 5
刪除 tb_emp2 表中的主鍵約束,SQL 語句和執行結果如下。
mysql> ALTER TABLE tb_emp2 -> DROP PRIMARY KEY; Query OK, 0 rows affected (0.94 sec) Records: 0 Duplicates: 0 Warnings: 0
由于主键约束在一个表中只能有一个,因此不需要指定主键名就可以删除一个表中的主键约束。
【相关推荐:mysql视频教程】
以上是mysql什麼叫主鍵的詳細內容。更多資訊請關注PHP中文網其他相關文章!