当前位置: 首页 > MySQL数据库

mysql怎么增加唯一索引

时间:2026-01-27 10:38:17

三种增加方法: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语句:

CREATEUNIQUEINDEX索引名ON表名(列名1,列名2,...);

在一列或多列中强制执行值唯一性的另一种方法是使用UNIQUE约束。

创建UNIQUE约束时,MySQL会UNIQUE在幕后创建索引。

以下语句说明了在创建表时如何创建唯一约束。

CREATETABLE表名(...UNIQUEKEY(列名1,列名2,...));

也可以使用ALTER TABLE语句给现有表添加唯一索引(UNIQUE)

ALTERTABLE表名ADDCONSTRAINT索引名UNIQUEKEY(列名1,列名2,...);

MySQL UNIQUE索引示例

假设您要管理应用程序中的联系人。您还希望contacts表中每个联系人的电子邮件必须是唯一的。

要强制执行此规则,请在CREATE TABLE语句中创建唯一约束,如下所示:

CREATETABLEIFNOTEXISTScontacts(idINTAUTO_INCREMENTPRIMARYKEY,first_nameVARCHAR(50)NOTNULL,last_nameVARCHAR(50)NOTNULL,phoneVARCHAR(15)NOTNULL,emailVARCHAR(100)NOTNULL,UNIQUEKEYunique_email(email));

如果使用SHOW INDEXES语句,您将看到MySQL UNIQUE为email列创建了索引。

SHOWINDEXESFROMcontacts;

让我们在contacts表格中插入一行。

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

现在,如果您尝试插入其电子邮件所在的行john.doe@mysqltutorial.org,您将收到错误消息。

INSERTINTOcontacts(first_name,last_name,phone,email)VALUES('Johny','Doe','(408)-999-4321','john.doe@mysqltutorial.org');
ERROR1062(23000):Duplicateentry'john.doe@mysqltutorial.org'forkey'unique_email'

假设你想要的组合first_name,last_name和 phone也接触中是唯一的。在这种情况下,您可以使用CREATE INDEX语句UNIQUE为这些列创建索引,如下所示:

CREATEUNIQUEINDEXidx_name_phoneONcontacts(first_name,last_name,phone);

添加下面一行到contacts因为组合表会导致错误first_name,last_name以及phone已经存在。

INSERTINTOcontacts(first_name,last_name,phone,email)VALUES('john','doe','(408)-999-9765','john.d@mysqltutorial.org');
ERROR1062(23000):Duplicateentry'john-doe-(408)-999-9765'forkey'idx_name_phone'

上一篇:mysql如何实现分组求和
下一篇:mysql如何查询第一条数据
mysql
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素