首页 > 数据库 >软件测试|MySQL唯一约束详解

软件测试|MySQL唯一约束详解

时间:2023-09-01 15:32:22浏览次数:43  
标签:name 表中 约束 +----------+-------------+------+-----+---------+-------+ 详解 MySQL 唯一

软件测试|MySQL唯一约束详解_mysql

简介

MySQL 唯一约束(Unique Key)是指所有记录中字段的值不能重复出现。MySQL中的唯一约束是一种用于确保表中某列或多列的取值唯一的数据库约束。唯一约束的作用是防止表中出现重复的值,确保数据的完整性和一致性。在本文中,我们将详细介绍MySQL中唯一约束的定义、用法以及其在数据库设计中的重要性。

什么是唯一约束?

唯一约束是一种用于限制数据库表中某列或多列取值的约束,确保这些列中的值各不相同。在定义了唯一约束的列上,数据库系统会自动检查插入或更新操作,确保数据的唯一性。如果有重复的值要被插入,或者违反了唯一性约束的值要被更新,数据库会拒绝这些操作并返回错误。

唯一约束的定义

在MySQL中,可以在创建表时或者后期通过ALTER TABLE语句来定义唯一约束。唯一约束可以应用于单个列,也可以应用于多个列,这取决于表的设计需求。

创建表时定义唯一约束

唯一约束可以在创建表时直接设置,通常设置在除了主键以外的其它列上。

在定义完列之后直接使用 UNIQUE 关键字指定唯一约束,语法格式如下:

CREATE TABLE table_name (
    column1 data_type UNIQUE,
    column2 data_type,
    ...
);

在上述示例中,UNIQUE关键字用于定义column1的唯一约束。这意味着column1中的值在表中是唯一的,不会出现重复值。

示例如下:

mysql> CREATE TABLE tb_dept2
    -> (
    -> id INT(11) PRIMARY KEY,
    -> name VARCHAR(22) UNIQUE,
    -> location VARCHAR(50)
    -> );
Query OK, 0 rows affected (0.37 sec)

mysql> DESC tb_dept2;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(11)     | NO   | PRI | NULL    |       |
| name     | varchar(40) | YES  | UNI | NULL    |       |
| location | varchar(50) | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.08 sec)

在修改表时添加唯一约束

在修改表时添加唯一约束的语法格式为:

ALTER TABLE table_name
ADD CONSTRAINT constraint_name UNIQUE (column1, column2, ...);

示例如下:

修改数据表 tb_dept1,指定部门的名称唯一,SQL 语句和运行结果如下所示。

mysql> ALTER TABLE tb_dept1
    -> ADD CONSTRAINT unique_name UNIQUE(name);
Query OK, 0 rows affected (0.63 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> DESC tb_dept1;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(11)     | NO   | PRI | NULL    |       |
| name     | varchar(22) | NO   | UNI | NULL    |       |
| location | varchar(50) | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

删除唯一约束

在 MySQL 中删除唯一约束的语法格式如下:

ALTER TABLE <table_name> DROP INDEX <constraint_name>;

示例如下:

删除数据表 tb_dept1 中的唯一约束 unique_name,SQL 语句和运行结果如下所示。

mysql> ALTER TABLE tb_dept1
    -> DROP INDEX unique_name;
Query OK, 0 rows affected (0.20 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> DESC tb_dept1;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(11)     | NO   | PRI | NULL    |       |
| name     | varchar(22) | NO   |     | NULL    |       |
| location | varchar(50) | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

唯一约束的意义

唯一约束在数据库设计中起到了关键作用。以下是它的主要意义:

  • 防止数据重复: 唯一约束确保表中特定列的值不重复。例如,在用户表中,可以使用唯一约束来确保每个用户的电子邮件地址是唯一的,避免了重复注册或登录的问题。
  • 替代主键(部分唯一约束): 在某些情况下,表中的主键可能由多列组成。如果某些列的组合能够唯一标识表中的每一行,但不是每一列单独标识行,那么可以使用唯一约束来替代主键。这样可以减少主键的复杂性,提高查询效率。
  • 加速查询: 唯一约束可以加速查询操作,特别是在涉及到唯一约束列的查找或连接时。数据库系统可以利用唯一索引来快速定位满足条件的行。

唯一约束和主键的区别

在MySQL中,唯一约束和主键是两种不同的约束类型,但它们都用于确保数据的唯一性。两者之间的区别如下:

  • 主键:主键是一种特殊的唯一约束,它要求列中的值唯一且不允许为空。一张表只能有一个主键,它在表中起到唯一标识每一行记录的作用。
  • 唯一约束:唯一约束要求列中的值唯一,但允许为空。一张表可以有多个唯一约束,用于保证不同列或组合的值唯一。

总结

唯一约束是MySQL中确保表中列值唯一性的重要手段。它能够防止数据重复,加速查询操作,同时在一些情况下也可以用来替代主键。在数据库设计过程中,合理使用唯一约束可以提高数据的完整性和查询性能,确保数据库表的稳健性和可靠性。但在应用唯一约束时,需要充分理解业务需求,避免不必要的复杂性,保持数据库结构的简洁性和高效性。

标签:name,表中,约束,+----------+-------------+------+-----+---------+-------+,详解,MySQL,唯一
From: https://blog.51cto.com/u_15640304/7323594

相关文章

  • 软件测试|MySQL 非空约束详解
    简介MySQL中的非空约束(NOTNULLConstraint)是一种用于确保表中某列不允许为空值的数据库约束。非空约束的作用是保证特定列的数据始终包含有效值,防止在插入或更新操作时出现空值,从而维护数据的完整性和一致性。在本文中,我们将详细介绍MySQL中非空约束的定义、用法以及在数据库设计......
  • Spring源码分析(十三)ApplicationContext详解(下)
    前面两篇文章,已经对ApplicationContext的大部分内容做了介绍,包括国际化,Spring中的运行环境,Spring中的资源,Spring中的事件监听机制,还剩唯一一个BeanFactory相关的内容没有介绍,这篇文章就来介绍BeanFactory,这篇文章介绍,关于ApplicationContext相关的内容总算可以告一段落了。本文对应......
  • mysql快速学习
    MySQL简介MySQL是关系型数据库(即通过外键关联来建立表与表的连接)补充一下非关系数据库NoSQL:非关系型数据库,常见的有Redis、mongoDB、CouchDB、cassandra等等特点:免费,开源数据库小巧,功能齐全使用便捷可运行于Windows或Linux操作系统可适用于中小型甚至大型网站应......
  • 243.mysql 内存统计相关
    1.查看mysql是否打开了关于innodb内存相关的监控SELECT*FROMperformance_schema.setup_instrumentsWHERENAMELIKE'%memory/innodb%';2.没有打开的话开一下(自己判断:重启数据库会恢复原有设置)#updateperformance_schema.setup_instrumentssetenabled='yes'wher......
  • Oracle数据迁移MySQL的三种简单方法
    Oracle数据迁移MySQL的三种简单方法更新时间:2023年06月05日10:58:16  作者:牛牛的笔记 对于许多企业而言,迁移数据库时最大的挑战之一是如何从一个数据库平台顺利迁移到另一个平台,下面这篇文章主要给大家介绍了关于Oracle数据迁移MySQL的三种简单方法,需要的朋友可以参......
  • MySQL InnoDB 是怎么使用 B+ 树存数据的?
    这里限定MySQLInnoDB存储引擎来进行阐述,避免不必要的阅读歧义。首先通过一篇文章简要了解下B树的相关知识:你好,我是B树。B+树是在B树基础上的变种,主要区别包括:1、所有数据都存储在叶节点,其它几点作为索引存储。2、数据节点添加链指针,便于横向检索。数据是怎么......
  • mysql字符集批量修改
    修改所有数据库字符集SELECTCONCAT('ALTERDATABASE',SCHEMA_NAME,'CHARACTERSETutf8mb4COLLATEutf8mb4_bin;')as'Fanrncho'FROMinformation_schema.`SCHEMATA`WHEREDEFAULT_CHARACTER_SET_NAMERLIKE'utf8mb4'ANDSCHEMA_NAME......
  • linux内核等待队列详解
    https://www.cnblogs.com/xinghuo123/p/13347964.html等待队列用于使得进程等待某一特定事件的发生,无需频繁的轮询,进程在等待周期中睡眠,当时间发生后由内核自动唤醒。1数据结构1.1等待队列头等待队列结构如下,因为每个等待队列都可以再中断时被修改,因此,在操作等待队列之前必......
  • mysql数据库性能优化参考
    原文链接:https://blog.csdn.net/qq_34777982/article/details/125788079硬件和操作系统层面的优化硬件:cpu、内存、磁盘io、网络带宽操作系统:应用文件句柄(ulimit-aopenfiles)网络配置架构设计层面的优化集群方式(主从集群或者主主集群):避免单点故障读写分离:读写分开,将压力分担,避......
  • 免苹果开发者账号申请iOS上架及证书打包ipa测试(2022最新详解)
    虽然xcode现在可以免证书进行测试了,但众多跨平台开发者,如果还没注册苹果开发者账号。想安装到自己非越狱手机测试是无能为力了。不过新技术来了,只需要普通免费的苹果账号无需付费成为开发者就可以申请ios证书打包ipa安装到自己手机测试,强大吧!这个神器就是Appuploader,iosapp测试及......