一、什么是唯一约束
唯一约束,指的是为表中的列提供唯一性保证,以确保列中的数据始终是唯一的。
有两种方式:
二、怎样界说唯一约束
MySQL中怎样界说唯一性约束呢?
有三种方法进行唯一约束的界说:
- 建表时直接在字段后面增加UNIQUE标识符
- 建表时在所有列的后面界说唯一约束
- 为已创建的表界说唯一约束
2.1、建表时界说唯一约束–方法1
第一种方法是直接在列的后面增加UNIQUE标识符:
- CREATE TABLE `t_test1` (
- `id` bigint NOT NULL PRIMARY KEY COMMENT '主键',
- `name` varchar(50) UNIQUE COMMENT '姓名' ,
- `phone` varchar(20) COMMENT '电话',
- `status` int DEFAULT '10' COMMENT '状态 10启用/20禁用',
- `valid` int DEFAULT '1' COMMENT '是否有效'
- ) COMMENT='用户表';
复制代码 说明:
- UNIQUE 的位置无需处于列的最末端(如图中所示),后面可界说COMMENT。
2.2、建表时界说唯一约束–方法2
第二种方法是在所有列的后面(列界说的末了一行)增加UNIQUE标识符。
语法如下:
UNIQUE $index_name($column_name[,…])
- CREATE TABLE `t_test2` (
- `id` bigint NOT NULL PRIMARY KEY COMMENT '主键',
- `name` varchar(50) COMMENT '姓名' ,
- `phone` varchar(20) COMMENT '电话',
- `status` int DEFAULT '10' COMMENT '状态 10启用/20禁用',
- `valid` int DEFAULT '1' COMMENT '是否有效',
- UNIQUE uc_name(name)
- ) COMMENT='用户表';
复制代码 说明:
- uc_name 是唯一索引的名称。
- 假如写成 UNIQUE (name) ,则唯一索引的名称等于列名。
为 多个列 添加唯一索引:
- CREATE TABLE `t_test2` (
- `id` bigint NOT NULL PRIMARY KEY COMMENT '主键',
- `name` varchar(50) COMMENT '姓名' ,
- `phone` varchar(20) COMMENT '电话',
- `status` int DEFAULT '10' COMMENT '状态 10启用/20禁用',
- `valid` int DEFAULT '1' COMMENT '是否有效',
- UNIQUE uc_id_name(id,`name`)
- ) COMMENT='用户表';
复制代码 说明:
- 只有当id和name都相同时,才认为是相同的数据。下面的数据则认为是差别的
也可以通过添加约束的方式界说唯一索引:
- CREATE TABLE `t_test3` (
- `id` bigint NOT NULL PRIMARY KEY COMMENT '主键',
- `name` varchar(50) COMMENT '姓名' ,
- `phone` varchar(20) COMMENT '电话',
- `status` int DEFAULT '10' COMMENT '状态 10启用/20禁用',
- `valid` int DEFAULT '1' COMMENT '是否有效',
- CONSTRAINT uc_name UNIQUE(`name`)
- ) COMMENT='用户表';
复制代码 注:省略了对多个列增加约束的演示。
2.3、为已创建的表界说唯一约束
假如表已经被创建,也可以对其界说唯一约束。
方法一
语法规则:
ALTER TABLE $table_name ADD UNIQUE [$index_name]($column_name[,…]);
例子:
- ALTER TABLE `t_test4`
- ADD UNIQUE (`name`);
- -- or
- ALTER TABLE `t_test4`
- ADD UNIQUE uc_name(`name`);
复制代码
- 省略唯一索引名称,则其名称和列名相同
- 多次执行上面的语句,会生成多个唯一索引(针对同一个列)
方法二
语法规则:
ALTER TABLE $table_name ADD CONSTRAINT [$index_name] UNIQUE($column_name[,…]);
例子:
- ALTER TABLE `t_test4`
- ADD CONSTRAINT UNIQUE(`name`);
- -- or
- ALTER TABLE `t_test4`
- ADD CONSTRAINT uc_name_1 UNIQUE (`name`);
复制代码
- CONSTRAINT后面接唯一索引名称,可省略
- 省略唯一索引名,索引名与列名相同
三、删除唯一约束
当唯一约束不再必要时,可通过下面的方法对其进行删除:
- ALTER TABLE `t_test3` DROP INDEX uc_name;
- -- 比较
- -- ALTER TABLE `t_test3` ADD UNIQUE uc_name (`name`);
复制代码
- 在删除唯一约束前,必要知道唯一索引的名称
- 注意DROP INDEX 中的 INDEX 不能少
比力一下新增唯一索引的脚本:
- 新增时,ADD 后面接的是 UNIQUE ,执行后会生成一个唯一索引
- 删除时使用的是DROP INDEX,因为唯一约束是一种索引。
四、题目
4.1、题目1:如作甚多个列界说唯一约束?
答:这个题目可参考文章的新增唯一约束部分。下面是其中一个简朴的做法:
- -- 为已存在的表创建唯一约束
- 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企服之家,中国第一个企服评测及商务社交产业平台。 |