溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

mysql怎么增加唯一索引

發(fā)布時(shí)間:2022-06-21 09:49:01 來(lái)源:億速云 閱讀:4173 作者:iii 欄目:MySQL數(shù)據(jù)庫(kù)

本篇內(nèi)容主要講解“mysql怎么增加唯一索引”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“mysql怎么增加唯一索引”吧!

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

本教程操作環(huán)境:windows7系統(tǒng)、mysql8版本、Dell G3電腦。

mysql唯一索引(UNIQUE)

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

幸運(yùn)的是,MySQL提供了另一種指標(biāo)叫做UNIQUE索引,使您可以強(qiáng)制執(zhí)行值的唯一的一列或多列。與PRIMARY KEY 索引不同,UNIQUE每個(gè)表可以有多個(gè)索引。

要?jiǎng)?chuàng)建UNIQUE索引,請(qǐng)使用以下CREATE INDEX語(yǔ)句:

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

在一列或多列中強(qiáng)制執(zhí)行值唯一性的另一種方法是使用UNIQUE約束。

創(chuàng)建UNIQUE約束時(shí),MySQL會(huì)UNIQUE在幕后創(chuàng)建索引。

以下語(yǔ)句說明了在創(chuàng)建表時(shí)如何創(chuàng)建唯一約束。

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

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

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

MySQL UNIQUE索引示例

假設(shè)您要管理應(yīng)用程序中的聯(lián)系人。您還希望contacts表中每個(gè)聯(lián)系人的電子郵件必須是唯一的。

要強(qiáng)制執(zhí)行此規(guī)則,請(qǐng)?jiān)贑REATE TABLE語(yǔ)句中創(chuàng)建唯一約束,如下所示:

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語(yǔ)句,您將看到MySQL UNIQUE為email列創(chuàng)建了索引。

SHOW INDEXES FROM contacts;

mysql怎么增加唯一索引

讓我們?cè)赾ontacts表格中插入一行。

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

mysql怎么增加唯一索引

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

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怎么增加唯一索引

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

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

添加下面一行到contacts因?yàn)榻M合表會(huì)導(dǎo)致錯(cuò)誤first_name,last_name以及phone已經(jīng)存在。

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'

到此,相信大家對(duì)“mysql怎么增加唯一索引”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI