mysql如何增加唯一索引
发布时间:2023-12-23 06:46:46 所属栏目:MySql教程 来源:DaWei
导读: 本篇内容主要讲解“mysql怎么增加唯一索引”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql怎么增加唯一索引”吧
本篇内容主要讲解“mysql怎么增加唯一索引”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql怎么增加唯一索引”吧! 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) ); 如果使用SHOW INDEXES语句,您将看到MySQL UNIQUE为email列创建了索引。 SHOW INDEXES FROM contacts; 让我们在contacts表格中插入一行。 INSERT INTO contacts(first_name,last_name,phone,email) VALUES('John','Doe','(408)-999-9765','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' 假设你想要的组合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怎么增加唯一索引”有了更深的了解,不妨来实际操作一番吧! (编辑:晋中站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐