[MySQL实战] 怎样界说唯一约束(唯一索引)

打印 上一主题 下一主题

主题 893|帖子 893|积分 2679




一、什么是唯一约束

唯一约束,指的是为表中的列提供唯一性保证,以确保列中的数据始终是唯一的。
有两种方式:


  • 将列设为主键
  • 为列增加唯一性约束
 
二、怎样界说唯一约束

MySQL中怎样界说唯一性约束呢?
有三种方法进行唯一约束的界说:


  • 建表时直接在字段后面增加UNIQUE标识符
  • 建表时在所有列的后面界说唯一约束
  • 为已创建的表界说唯一约束
2.1、建表时界说唯一约束–方法1

第一种方法是直接在列的后面增加UNIQUE标识符:
  1. CREATE TABLE `t_test1` (
  2.   `id` bigint NOT NULL PRIMARY KEY COMMENT '主键',
  3.   `name` varchar(50) UNIQUE COMMENT '姓名' ,
  4.   `phone` varchar(20) COMMENT '电话',
  5.   `status` int DEFAULT '10' COMMENT '状态 10启用/20禁用',
  6.   `valid` int DEFAULT '1' COMMENT '是否有效'
  7. ) COMMENT='用户表';
复制代码
说明:


  • UNIQUE 的位置无需处于列的最末端(如图中所示),后面可界说COMMENT。
2.2、建表时界说唯一约束–方法2

第二种方法是在所有列的后面(列界说的末了一行)增加UNIQUE标识符。
语法如下:
   UNIQUE $index_name($column_name[,…])
  1. CREATE TABLE `t_test2` (
  2.   `id` bigint NOT NULL PRIMARY KEY COMMENT '主键',
  3.   `name` varchar(50) COMMENT '姓名' ,
  4.   `phone` varchar(20) COMMENT '电话',
  5.   `status` int DEFAULT '10' COMMENT '状态 10启用/20禁用',
  6.   `valid` int DEFAULT '1' COMMENT '是否有效',
  7.   UNIQUE uc_name(name)
  8. ) COMMENT='用户表';
复制代码
说明:


  • uc_name 是唯一索引的名称。
  • 假如写成 UNIQUE (name) ,则唯一索引的名称等于列名。
多个列 添加唯一索引:
  1. CREATE TABLE `t_test2` (
  2.   `id` bigint NOT NULL PRIMARY KEY COMMENT '主键',
  3.   `name` varchar(50) COMMENT '姓名' ,
  4.   `phone` varchar(20) COMMENT '电话',
  5.   `status` int DEFAULT '10' COMMENT '状态 10启用/20禁用',
  6.   `valid` int DEFAULT '1' COMMENT '是否有效',
  7.   UNIQUE uc_id_name(id,`name`)
  8. ) COMMENT='用户表';
复制代码
说明:


  • 只有当id和name都相同时,才认为是相同的数据。下面的数据则认为是差别的

也可以通过添加约束的方式界说唯一索引:
  1. CREATE TABLE `t_test3` (
  2.   `id` bigint NOT NULL PRIMARY KEY COMMENT '主键',
  3.   `name` varchar(50) COMMENT '姓名' ,
  4.   `phone` varchar(20) COMMENT '电话',
  5.   `status` int DEFAULT '10' COMMENT '状态 10启用/20禁用',
  6.   `valid` int DEFAULT '1' COMMENT '是否有效',
  7.   CONSTRAINT uc_name UNIQUE(`name`)
  8. ) COMMENT='用户表';
复制代码
注:省略了对多个列增加约束的演示。
2.3、为已创建的表界说唯一约束

假如表已经被创建,也可以对其界说唯一约束。
方法一
语法规则:
   ALTER TABLE $table_name ADD UNIQUE [$index_name]($column_name[,…]);
  例子:
  1. ALTER TABLE `t_test4`
  2. ADD UNIQUE (`name`);
  3. -- or
  4. ALTER TABLE `t_test4`
  5. ADD UNIQUE uc_name(`name`);
复制代码


  • 省略唯一索引名称,则其名称和列名相同
  • 多次执行上面的语句,会生成多个唯一索引(针对同一个列)
方法二
语法规则:
   ALTER TABLE $table_name ADD CONSTRAINT [$index_name] UNIQUE($column_name[,…]);
  例子:
  1. ALTER TABLE `t_test4`
  2. ADD CONSTRAINT UNIQUE(`name`);
  3. -- or
  4. ALTER TABLE `t_test4`
  5. ADD CONSTRAINT uc_name_1 UNIQUE (`name`);
复制代码


  • CONSTRAINT后面接唯一索引名称,可省略
  • 省略唯一索引名,索引名与列名相同
三、删除唯一约束

当唯一约束不再必要时,可通过下面的方法对其进行删除:
  1. ALTER TABLE `t_test3` DROP INDEX uc_name;
  2. -- 比较
  3. -- ALTER TABLE `t_test3` ADD UNIQUE uc_name (`name`);
复制代码


  • 在删除唯一约束前,必要知道唯一索引的名称
  • 注意DROP INDEX 中的 INDEX 不能少
比力一下新增唯一索引的脚本:


  • 新增时,ADD 后面接的是 UNIQUE ,执行后会生成一个唯一索引
  • 删除时使用的是DROP INDEX,因为唯一约束是一种索引。
四、题目

4.1、题目1:如作甚多个列界说唯一约束?

答:这个题目可参考文章的新增唯一约束部分。下面是其中一个简朴的做法:
  1. -- 为已存在的表创建唯一约束
  2. ALTER TABLE `t_test4` ADD UNIQUE uc_id_name(id,`name`);
复制代码
 
五、总结

  本文讲解了MySQL数据库中界说唯一约束的几种方法,并夸大了一些注意点。在平时的工作中可以按需选择。
  对于不再必要的唯一约束,可以对其进行删除。因为唯一约束本质上就是索引,以是必要使用索引删除语句对其进行删除。
 
 

参考资料:
https://www.w3schools.cn/mysql/mysql_unique.asp
https://www.cnblogs.com/sun-yanglu/p/9581701.html
 
 
 
 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

络腮胡菲菲

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表