亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql怎么增加唯一索引

發布時間:2022-06-21 09:49:01 來源:億速云 閱讀:4184 作者:iii 欄目:MySQL數據庫

本篇內容主要講解“mysql怎么增加唯一索引”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“mysql怎么增加唯一索引”吧!

三種增加方法:1、使用“CREATE INDEX”語句增加,語法“CREATE UNIQUE INDEX 索引名 ON 表名(列名列表);”;2、建表時增加,語法“CREATE TABLE 表名(... UNIQUE KEY(列名列表) );”;3、修改表時增加,語法“ALTER TABLE 表名 ADD CONSTRAINT 索引名 UNIQUE KEY(列名列表);”。

本教程操作環境:windows7系統、mysql8版本、Dell G3電腦。

mysql唯一索引(UNIQUE)

要強制執行一列或多列的唯一性值,通常使用PRIMARY KEY約束。但是,每個表只能有一個主鍵。因此,如果要包含多個列或一組具有唯一值的列,則不能使用主鍵約束。

幸運的是,MySQL提供了另一種指標叫做UNIQUE索引,使您可以強制執行值的唯一的一列或多列。與PRIMARY KEY 索引不同,UNIQUE每個表可以有多個索引。

要創建UNIQUE索引,請使用以下CREATE INDEX語句:

CREATE UNIQUE INDEX 索引名
ON 表名(列名1,列名2,...);

在一列或多列中強制執行值唯一性的另一種方法是使用UNIQUE約束。

創建UNIQUE約束時,MySQL會UNIQUE在幕后創建索引。

以下語句說明了在創建表時如何創建唯一約束。

CREATE TABLE 表名(
...
   UNIQUE KEY(列名1,列名2,...) 
);

也可以使用ALTER TABLE語句給現有表添加唯一索引(UNIQUE)

ALTER TABLE 表名
ADD CONSTRAINT 索引名 UNIQUE KEY(列名1,列名2,...);

MySQL UNIQUE索引示例

假設您要管理應用程序中的聯系人。您還希望contacts表中每個聯系人的電子郵件必須是唯一的。

要強制執行此規則,請在CREATE TABLE語句中創建唯一約束,如下所示:

CREATE TABLE IF NOT EXISTS contacts (
    id INT AUTO_INCREMENT PRIMARY KEY,
    first_name VARCHAR(50) NOT NULL,
    last_name VARCHAR(50) NOT NULL,
    phone VARCHAR(15) NOT NULL,
    email VARCHAR(100) NOT NULL,
    UNIQUE KEY unique_email (email)
);

mysql怎么增加唯一索引

如果使用SHOW INDEXES語句,您將看到MySQL UNIQUE為email列創建了索引。

SHOW INDEXES FROM contacts;

mysql怎么增加唯一索引

讓我們在contacts表格中插入一行。

INSERT INTO contacts(first_name,last_name,phone,email)
VALUES('John','Doe','(408)-999-9765','john.doe@mysqltutorial.org');

mysql怎么增加唯一索引

現在,如果您嘗試插入其電子郵件所在的行john.doe@mysqltutorial.org,您將收到錯誤消息。

INSERT INTO contacts(first_name,last_name,phone,email)
VALUES('Johny','Doe','(408)-999-4321','john.doe@mysqltutorial.org');
ERROR 1062 (23000): Duplicate entry 'john.doe@mysqltutorial.org' for key 'unique_email'

mysql怎么增加唯一索引

假設你想要的組合first_name,last_name和   phone也接觸中是唯一的。在這種情況下,您可以使用CREATE INDEX語句UNIQUE為這些列創建索引,如下所示:

CREATE UNIQUE INDEX idx_name_phone
ON contacts(first_name,last_name,phone);

添加下面一行到contacts因為組合表會導致錯誤first_name,last_name以及phone已經存在。

INSERT INTO contacts(first_name,last_name,phone,email)
VALUES('john','doe','(408)-999-9765','john.d@mysqltutorial.org');
ERROR 1062 (23000): Duplicate entry 'john-doe-(408)-999-9765' for key 'idx_name_phone'

到此,相信大家對“mysql怎么增加唯一索引”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

碌曲县| 镶黄旗| 酒泉市| 冀州市| 怀宁县| 常山县| 江阴市| 辽阳县| 印江| 丹寨县| 桦川县| 永登县| 罗定市| 邢台市| 河南省| 都安| 福州市| 英德市| 民乐县| 涿鹿县| 龙岩市| 天峨县| 阜康市| 盐池县| 阿荣旗| 萝北县| 灵石县| 通化县| 东丰县| 屏东县| 静宁县| 金沙县| 宝应县| 西藏| 兴安县| 大庆市| 任丘市| 仁怀市| 香河县| 炉霍县| 泽普县|