mysql怎么增加唯一索引

网友投稿 331 2023-11-23

mysql怎么增加唯一索引

本篇内容主要讲解“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(50NOT NULL,     last_name VARCHAR(50NOT NULL,     phone VARCHAR(15NOT NULL,     emailVARCHAR(100NOT NULL,     UNIQUE KEY unique_email (email) );

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

SHOW INDEXES FROM contacts;

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

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

现在,如果您尝试插入其电子邮件所在的行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.orgfor keyunique_email

假设你想要的组合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怎么增加唯一索引”有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:mysql如何统计查询结果
下一篇:国产数据库与开源代码
相关文章

 发表评论

暂时没有评论,来抢沙发吧~