[MySQL实战] 如何定义唯一约束(唯一索引)

文章目录

    • 一、什么是唯一约束
    • 二、如何定义唯一约束
      • 2.1、建表时定义唯一约束--方法1
      • 2.2、建表时定义唯一约束--方法2
      • 2.3、为已创建的表定义唯一约束
    • 三、删除唯一约束
    • 四、问题
      • 4.1、问题1:如何为多个列定义唯一约束?
    • 五、总结


cover


一、什么是唯一约束

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

  • 将列设为主键
  • 为列增加唯一性约束

 

二、如何定义唯一约束

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

 
 
 
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/479591.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

速通Markdown基础写法(含安装Typora)

什么是Markdown Markdown是一种轻量级标记语言,它允许人们使用易读易写的纯文本格式来编写文档,然后转换成格式丰富的HTML页面。这种语言吸收了很多在电子邮件中已有的纯文本标记的特性。 Markdown的语法简洁明了、学习容易,而且功能比纯文…

(2024,Mamba,DiT,之字扫描与空间连续性)ZigMa:之字形 Mamba 扩散模型

ZigMa: Zigzag Mamba Diffusion Model 公和众和号:EDPJ(进 Q 交流群:922230617 或加 VX:CV_EDPJ 进 V 交流群) 目录 0. 摘要 1. 简介 2. 相关工作 3. 方法 3.1 背景:状态空间模型 3.2 扩散主干&…

Springboot开发中可能遇到的问题

SpringBoot特征: 1. SpringBoot Starter:他将常用的依赖分组进行了整合,将其合并到一个依赖中,这样就可以一次性添加到项目的Maven或Gradle构建中。 2,使编码变得简单,SpringBoot采用 JavaConfig的方式对Spring进行配置…

全网最靠谱的短网址平台,你知道几个?

在当今互联网时代,短网址平台成为了人们分享链接的常用工具。它们不仅可以将冗长的网址压缩为简洁的短链接,还能提供更多的功能和优势。在众多的短网址平台中,有几个平台以其可靠性和出色的性能脱颖而出。今天,我们就来介绍几个全…

ssh介绍

1. 什么是SSH? SSH是一种网络协议,用于计算机之间的加密登录。最早的时候,互联网通信都是明文通信,一旦被截获,内容就暴露无疑。1995年,芬兰学者Tatu Ylonen设计了SSH协议,将登录信息全部加密&…

多线程基础 -概念、创建、等待、分离、终止

文章目录 一、 线程概念1. 什么是线程2. 线程的优点3.线程的缺点4. 线程异常5. 线程用途 二、 Linux进程VS线程1. 进程和线程2. 进程和线程的地址空间3. 进程和线程的关系 三、Linux线程控制1. POSIX线程库2. 线程创建3. 线程ID及进程地址空间布局4. 线程终止5. 线程等待6. 线程…

【pcolor数据可视化】Matlab vs. Python

1、Matlab代码及结果 代码 clear;clc load(.\nclcolormap.mat)sl [0,50,100,200,500,0]; el [50,100,200,500,1000,200];for i 1:length(sl)file [..\data\static_result\VIS_Min-,num2str(sl(i)),to,num2str(el(i)),_yearly.npy];data readNPY(file);maskreadNPY(.\mas…

基于springboot的mysql实现读写分离

前言: 首先思考一个问题:在高并发的场景中,关于数据库都有哪些优化的手段?常用的有以下的实现方法:读写分离、加缓存、主从架构集群、分库分表等,在互联网应用中,大部分都是读多写少的场景,设置两个库,主库和读库,主库的职能是负责写,从库主要是负责读…

FloodFill算法——图像渲染

文章目录 题目解析题目内容解读 算法解析代码解析 题目解析 首先我们先来看看题目:图像渲染 题目内容解读 我们来解读一下题目内容这个题目的意思其实就是有一个如下图所示的二维矩阵 这个题目的意思在这类题目中也是非常标准的,就是给我们一个二维数…

yaml 语法和在线解析工具

文章目录 在线解析工具1. 简介2. 语法规则3. 数据类型3.1 数组:3.2对象:3.3 标量3.4 复合结构3.5 锚点3.5.1 单个锚点3.5.6 多个锚点 3.6 引号 参考 在线解析工具 工具1 工具2 1. 简介 Yaml是一种可读性高的数据标记语言,Yaml文件是一种配…

python基础知识(三)基本编程题,应用题

基本编程题 1.从键盘输入一个整数和一个字符,以逗号隔开,在屏慕上显示输出一条信息。 示例如下: 输入: 10, 输出: 10 s input("请输入一个整数和一个字符,用逗号隔开:")l s.split(",&q…

使用vscode调试代码

Step1:在系统中安装gdb 在Ubuntu系统下安装gdb: apt-get update apt-get install gdb 在CentOS系统下安装gdb: yum install gdb Step2:编译生成Debug版本的可执行程序 假设源文件名称为test.cpp,使用g编译器&#…

你不知道的console

console console 对象提供了浏览器控制台调试的接口,我们可以从任何全局对象中访问到它,在不同浏览器上它的工作方式可能不一样,但通常都会提供一套共性的功能。 1.console.log() 打印内容的通用方法,使用方法可以参考使用字符…

DBO优化LSBoost回归预测(matlab代码)

DBO-LSBoost回归预测matlab代码 蜣螂优化算法(Dung Beetle Optimizer, DBO)是一种新型的群智能优化算法,在2022年底提出,主要是受蜣螂的的滚球、跳舞、觅食、偷窃和繁殖行为的启发。 数据为Excel股票预测数据。 数据集划分为训练集、验证集、测试集,比…

【系统架构师】-计算机网络

1、网络的划分 网络性能指标:速率、带宽(频带宽度或传送线路速率)、吞吐量、时延、往返时间、利用率。 网络非性能指标:费用、质量、标准化、可靠性、可扩展性、可升级性、易管理性和可维护性。 总线型(利用率低、干扰大、价格低)、 星型(交换机转发形…

【Linux】系统开启和关闭过程

Linux 系统启动过程 BIOS 自检:在计算机开机时,BIOS 会进行自检,检查硬件设备是否正常。 加载引导程序:BIOS 自检完成后,会加载引导程序,如 GRUB、LILO 等。引导程序会加载内核和初始化 RAM 磁盘&#xff…

数据结构:详解【栈和队列】的实现

目录 1. 栈1.1 栈的概念及结构1.2 栈的实现1.3 栈的功能1.4 栈的功能的实现1.5 完整代码 2. 队列2.1 队列的概念及结构2.2 队列的实现2.3 队列的功能2.4 队列的功能的实现2.5 完整代码 1. 栈 1.1 栈的概念及结构 栈:一种特殊的线性表,其只允许在固定的…

如何看待腾讯 QQ 浏览器抄袭 Arc

今天在 Reddit 的帖子上看到,QQ 浏览器抄袭了 Arc 而且还是 Arc 官方发布的 It looks very similar lol 看起来也太像了,笑死我了 稍微震惊了一下,带着疑惑,打开了 QQ 浏览器官网页 点击下载 ⬇️ 下载后打开 翻找了下&#xff0…

2004-2022年各省化学需氧量数据(无缺失)

2004-2022年各省化学需氧量数据(无缺失) 1、2004-2022年 2、范围:31省 3、指标:化学需氧量 4、来源:各省年鉴、国家统计局、环境年鉴 5、指标解释:化学需氧量(COD)排放量指工业废水中COD排放量与生活污…

java 泛型(下)

本篇文章主要说明的是类型通配符、可变参数、可变参数的使用等。 在学习之前,希望能对泛型有个大概了解,可参考链接 java 泛型(上)-CSDN博客 也希望对泛型类、泛型接口、泛型方法有个大概的认识及使用,可参考链接 j…