三种增加方法: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(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');
现在,如果您尝试插入其电子邮件所在的行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_phoneON 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怎么增加少数索引”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
文章标题:mysql怎么增加少数索引,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/29020