• 技术文章 >数据库 >mysql教程

    mysql如何增加唯一索引

    青灯夜游青灯夜游2022-06-20 18:50:20原创444

    三种增加方法: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)
    );

    1.png

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

    SHOW INDEXES FROM contacts;

    2.png

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

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

    3.png

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

    4.png

    假设你想要的组合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视频教程

    以上就是mysql如何增加唯一索引的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:mysql
    上一篇:mysql中not null是索引吗 下一篇:mysql怎么统计查询结果
    20期PHP线上班

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• mysql分页查询怎么优化• mysql怎么关闭事务• 怎么查询mysql中所有表• mysql中not null是索引吗
    1/1

    PHP中文网