久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

mysql怎么增加唯一索引

共計(jì) 2039 個(gè)字符,預(yù)計(jì)需要花費(fèi) 6 分鐘才能閱讀完成。

本篇內(nèi)容主要講解“mysql 怎么增加唯一索引”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓丸趣 TV 小編來(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ǔ)句說(shuō)明了在創(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)?CREATE 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)
);

如果使用 SHOW INDEXES 語(yǔ)句,您將看到 MySQL UNIQUE 為 email 列創(chuàng)建了索引。

SHOW INDEXES FROM contacts;

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

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

現(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

假設(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í)際操作一番吧!這里是丸趣 TV 網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!

正文完
 
丸趣
版權(quán)聲明:本站原創(chuàng)文章,由 丸趣 2023-07-13發(fā)表,共計(jì)2039字。
轉(zhuǎn)載說(shuō)明:除特殊說(shuō)明外本站除技術(shù)相關(guān)以外文章皆由網(wǎng)絡(luò)搜集發(fā)布,轉(zhuǎn)載請(qǐng)注明出處。
評(píng)論(沒(méi)有評(píng)論)
主站蜘蛛池模板: 驻马店市| 开阳县| 山西省| 阳原县| 阜南县| 阜新市| 台中市| 体育| 建瓯市| 辰溪县| 铜陵市| 福鼎市| 天气| 蒙阴县| 襄汾县| 红原县| 峡江县| 富蕴县| 依安县| 新田县| 迁西县| 青神县| 房产| 晋州市| 兰西县| 阜宁县| 民县| 兴义市| 天津市| 锡林浩特市| 什邡市| 保德县| 四平市| 万载县| 雷山县| 安国市| 谷城县| 库尔勒市| 博白县| 赤峰市| 沾益县|