真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

mysql添加主鍵的方法

這篇文章給大家分享的是有關(guān)MySQL添加主鍵的方法的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)是一家專注于網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì)與策劃設(shè)計(jì),無極網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:無極等地區(qū)。無極做網(wǎng)站價格咨詢:13518219792

“主鍵(PRIMARY KEY)”的完整稱呼是“主鍵約束”。MySQL 主鍵約束是一個列或者列的組合,其值能唯一地標(biāo)識表中的每一行。這樣的一列或多列稱為表的主鍵,通過它可以強(qiáng)制表的實(shí)體完整性。那么在MySQL中如何添加主鍵約束?下面本篇文章就給大家介紹一下。

mysql添加主鍵的方法

主鍵約束即在表中定義一個主鍵來唯一確定表中每一行數(shù)據(jù)的標(biāo)識符。主鍵可以是表中的某一列或者多列的組合,其中由多列組合的主鍵稱為復(fù)合主鍵。主鍵應(yīng)該遵守下面的規(guī)則:

● 每個表只能定義一個主鍵。

● 主鍵值必須唯一標(biāo)識表中的每一行,且不能為 NULL,即表中不可能存在兩行數(shù)據(jù)有相同的主鍵值。這是唯一性原則。

● 一個列名只能在復(fù)合主鍵列表中出現(xiàn)一次。

● 復(fù)合主鍵不能包含不必要的多余列。當(dāng)把復(fù)合主鍵的某一列刪除后,如果剩下的列構(gòu)成的主鍵仍然滿足唯一性原則,那么這個復(fù)合主鍵是不正確的。這是最小化原則。

1、在創(chuàng)建表時添加主鍵約束

在 CREATE TABLE 語句中,主鍵是通過 PRIMARY KEY 關(guān)鍵字來指定的。

在定義列的同時指定主鍵,語法規(guī)則如下:

<字段名> <數(shù)據(jù)類型> PRIMARY KEY [默認(rèn)值]

例:在 test_db 數(shù)據(jù)庫中創(chuàng)建 tb_emp 1 數(shù)據(jù)表,其主鍵為 id

mysql> CREATE TABLE tb_emp1
    -> (
    -> id INT(11) PRIMARY KEY,
    -> name VARCHAR(25),
    -> deptId INT(11),
    -> salary FLOAT
    -> );
Query OK, 0 rows affected (0.37 sec)
mysql> DESC tb_emp1;
+--------+-------------+------+-----+---------+-------+
| 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 [字段名]

示例:在 test_db 數(shù)據(jù)庫中創(chuàng)建 tb_emp 2 數(shù)據(jù)表,其主鍵為 id

mysql> CREATE TABLE tb_emp2
    -> (
    -> 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_emp2;
+--------+-------------+------+-----+---------+-------+
| 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、在創(chuàng)建表后添加主鍵約束

創(chuàng)建表后,可以在修改數(shù)據(jù)表時添加主鍵約束,語法規(guī)則為:

ALTER TABLE <數(shù)據(jù)表名> ADD PRIMARY KEY(<列名>);

示例:修改數(shù)據(jù)表 tb_emp3,將字段 id 設(shè)置為主鍵

mysql> ALTER TABLE tb_emp3
    -> ADD PRIMARY KEY(id);
Query OK, 0 rows affected (0.94 sec)
Records: 0  Duplicates: 0  Warnings: 0
mysql> DESC tb_emp3;
+--------+-------------+------+-----+---------+-------+
| 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)

3、設(shè)置復(fù)合主鍵

也可以在創(chuàng)建表時添加復(fù)合主鍵,此時主鍵由多個字段聯(lián)合組成,語法規(guī)則如下:

PRIMARY KEY [字段1,字段2,…,字段n]

示例:創(chuàng)建數(shù)據(jù)表 tb_emp4,假設(shè)表中沒有主鍵 id,為了唯一確定一個員工,可以把 name、deptId 聯(lián)合起來作為主鍵

mysql> CREATE TABLE tb_emp4
    -> (
    -> name VARCHAR(25),
    -> deptId INT(11),
    -> salary FLOAT,
    -> PRIMARY KEY(id,deptId)
    -> );
Query OK, 0 rows affected (0.37 sec)
mysql> DESC tb_emp4;
+--------+-------------+------+-----+---------+-------+
| 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)

感謝各位的閱讀!關(guān)于mysql添加主鍵的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!


分享文章:mysql添加主鍵的方法
轉(zhuǎn)載來源:http://weahome.cn/article/psehpj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部