当前位置: 首页 > news >正文

【mysql】—— 表的约束

目录

序言

(一)空属性

(二)默认值

(三)列描述

(四)zerofill

(五)主键

(六)自增长

(七)唯一键

(八)外键

总结


序言

真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。
 

定义:

  • 因此在数据库中,表的约束(cyonstraint)是用来定义表中数据的规则和限制的规则。它们用于确保数据的完整性和一致性,并防止非法数据的插入、更新或删除。通过定义约束,可以强制执行特定的条件和规定,以确保数据的正确性和质量。

常见的表约束类型包括:

  1. 主键约束(Primary Key Constraint):定义一列或一组列作为唯一标识表中的每一行。主键用于确保唯一性和数据的完整性。

  2. 唯一约束(Unique Constraint):确保一列或一组列中的所有值都是唯一的,但可以有空值。它防止重复的数据。

  3. 外键约束(Foreign Key Constraint):用于确保表之间的关系的完整性。它定义了对其他表中的主键或唯一键的引用,可以用于建立表之间的关联。

  4. 非空约束(Not Null Constraint):指定一列不允许包含空值(NULL)。它确保必须为该列提供值。

  5. 默认约束(Default Constraint):定义一列的默认值,如果在插入新行时没有提供该列的值,则将使用默认值。

  6. 检查约束(Check Constraint):定义一列的取值范围或条件。它用于限制该列可以接受的数据。

这些约束可以单独应用于列或多个列,也可以组合使用。通过使用表的约束,可以在数据库层面上对数据进行验证和限制,以提高数据的完整性和一致性。


(一)空属性

  1. 两个值:null(默认的)和not null(不为空)
  2. 数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算

 

案例:
创建一个班级表,包含班级名和班级所在的教室。
站在正常的业务逻辑中:

  1. 如果班级没有名字,你不知道你在哪个班级
  2. 如果教室名字可以为空,就不知道在哪上课

所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。这就是“约束”。
 

  •  插入数据时,没有给教室数据插入失败:

 


(二)默认值

在 MySQL 中,可以使用默认值约束(Default Constraint)来为表中的列指定默认值。这样,在插入新行时,如果没有提供该列的具体值,将自动使用默认值。

以下是一个示例,创建一个带有默认值约束的 users 表:

  • 在上述示例中,name email 列都被定义为具有默认值。当插入数据时,如果不提供指定列的值,则会自动使用默认值。 

默认值的生效:数据在插入的时候不给该字段赋值,就使用默认值
 

 

其次。如果要修改现有表中的列的默认值,可以使用 ALTER TABLE 命令:

 


(三)列描述

在 MySQL 中,可以使用列描述(Column Description)来为表中的列添加描述信息。列描述是一个可选的元数据属性,用于提供关于列的更多详细信息,如列的用途、含义或任何其他相关说明。

以下是一个示例,创建一个带有列描述的 t1表:

 

通过desc查看不到注释信息:
 

 通过show可以看到:

 

 


(四)zerofill

在 MySQL 中,ZEROFILL 是一种表约束,用于在存储数值类型的列中填充零以达到指定的位数。它将使数值在显示时占据固定的位数,并在必要时用零填充不足的部分。

要使用 ZEROFILL 约束,您需要将其与数值列一起使用,如 INTBIGINTFLOATDOUBLE 等。在列定义中,通过添加 ZEROFILL 关键字并指定所需的位数,来启用零填充。

 可以看到int(10),这个代表什么意思呢?整型不是4字节码?这个10又代表什么呢?其实没有zerofill这个属性,括号内的数字是毫无意义的。a和b列就是前面插入的数据,如下:
 

 

但是对列添加了zerofill属性后,显示的结果就有所不同了。修改 t2 表的属性:
 

 

对a列添加了zerofill属性,再进行查找,返回如下结果:
 

【结论】 

  •  这次可以看到a的值由原来的1变成00001,这就是zerofill属性的作用,如果宽度小于设定的宽度,自动填充0。要注意的是,这只是最后显示的结果,在MySQL中实际存储的还是1。

为什么是这样呢?我们可以用hex函数来证明:

 

 

  • 可以看出数据库内部存储的还是1,00001只是设置了zerofill属性后的一种格式化输出而已。
     

紧接着,我们把 a中的 int() 中的值改为5之后,在来进行插入操作:

 插入操作如下:

【结论】 

 当我们查看当前表时,可以发现一个问题:

  1. 当我们插入的小于5位时,缺少的用0补齐;
  2. 当超过五位时,系统就按照插入的数据原样的输出

最后解答为什么我们创建的默认是 int(10)?

  1. 首先,因为我们创建的类型是 unsigned类型,而 unsigned 的取值范围为【0,2^32-1】;
  2. 而 2^32-1 的数值范围是 10位整数,因此当我们查看时默认的是 int(10)

 小结:使用 ZEROFILL 约束可以方便地进行数字显示和格式化,特别适用于需要固定位数的标识符或编码的情况。


(五)主键

在 MySQL 中,主键约束(Primary Key Constraint)用于定义表中一列或多列作为唯一标识表中的每一行的约束条件。主键约束是一种重要的约束,用于确保数据的唯一性和完整性。

主键约束有以下特点:

  1. 唯一性:主键的值在整个表中必须是唯一的,即每一行的主键值都不相同。
  2. 非空性:主键列的值不能为 NULL,即主键列不能为空。
  3. 唯一标识性:主键用于唯一标识表中的每一行,从而方便对表中的数据进行准确定位和关联。

【案例】

  • 创建表的时候直接在字段上指定主键
     

  •  主键约束:主键对应的字段中不能重复,一旦重复,操作失败。

  •  当表创建好以后但是没有主键的时候,可以再次追加主键

 

  • 删除主键
     

 

  • 复合主键
     

在创建表的时候,在所有字段之后,使用primary key(主键字段列表)来创建主键,如果有多个字段
作为主键,可以使用复合主键
 

 

 

通过指定主键约束,可以确保表中的数据具有唯一的标识,并对数据的完整性进行验证和保护。


(六)自增长

在 MySQL 中,自增长(Auto_increment)是一种用于表的列的约束,它允许数据库自动为每个新插入的行分配唯一的递增值。自增长列通常用作表的主键列,以确保每个新插入的行都具有唯一且递增的标识符。

auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。


自增长的特点:

  1. 任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)
  2. 自增长字段必须是整数
  3. 一张表最多只能有一个自增长
     

【案例】

 

在插入后获取上次插入的 AUTO_INCREMENT 的值(批量插入获取的是第一个值)
 

【 索引】

在关系数据库中,索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结
构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。索引的作用相当于图书的目录,可以根据目录中的页码快速找到所需的内容。


索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序。
数据库使用索引以找到特定值,然后顺指针找到包含该值的行。这样可以使对应于表的SQL语句执行得更快,可快速访问数据库表中的特定信息。

通过自增长约束,可以轻松生成并维护具有唯一标识的行,减少了手动提供标识符的工作和可能的冲突。自增长列通常用作主键列,以实现高效的数据插入和查找。


(七)唯一键

在 MySQL 中,唯一键(Unique Key)是一种约束,用于确保表中的列或列组合的值在整个表中是唯一的。唯一键约束类似于主键约束,但它允许空值(NULL),并且可以应用于多个列。

唯一键约束有以下特点:

  1. 唯一性:唯一键的值在整个表中必须是唯一的,即每一行的唯一键值都不能与其他行的唯一键值重复。
  2. 可以包含 NULL 值:唯一键列允许包含 NULL 值。由于 NULL 不等于 NULL,因此两个包含 NULL 值的行不会违反唯一键约束。

关于唯一键和主键的区别:

  1. 我们可以简单理解成,主键更多的是标识唯一性的;
  2. 而唯一键更多的是保证在业务上,不要和别的信息出现重复。
     

 

  • 唯一约束不能重复,但可以为空:
     

 

通过使用唯一键约束,可以确保表中的列或列组合具有唯一的值,从而确保数据的完整性和一致性。与主键约束相比,唯一键约束允许空值,并且可以应用于多个列,提供更大的灵活性。


(八)外键

在 MySQL 中,外键(Foreign Key)是一种约束,用于确保表之间的数据完整性和一致性。外键定义了表之间的关联关系,它基于一个表中的列值与另一个表中的列值之间的关系。

外键约束有以下特点:

  1. 关联关系:外键约束用于定义表之间的关联关系,其中一个表(称为子表)的列值必须存在于另一个表(称为父表)的列值中。
  2. 数据完整性:外键约束确保关联的数据在父表中存在,从而保持数据的完整性和一致性。它防止在子表中插入无效的或不一致的数据。
  3. 可选性:外键列可以为空或包含 NULL 值,但如果包含值,则该值必须在父表中存在。

要使用外键约束,需要满足以下条件:

  1. 子表和父表之间必须存在关联的列,子表中的列用于引用父表中的列。
  2. 父表中的关联列必须具有唯一约束或主键约束。

语法

  • foreign key (字段名) references 主表(列)

【案例】

 对上面的示意图进行设计:

  • 先创建主键表
     

 

  • 再创建从表:

  •  正常进行插入数据:

  •  插入一个班级号为30的学生,因为没有这个班级,所以插入不成功:

  •  插入班级id为null,比如来了一个学生,目前还没有分配班级:

  •  如何理解外键约束:

首先我们承认,这个世界是数据很多都是相关性的。


理论上,上面的例子,我们不创建外键约束,就正常建立学生表,以及班级表,该有的字段我们都有。


此时,在实际使用的时候,可能会出现什么问题?

  1. 有没有可能插入的学生信息中有具体的班级,但是该班级却没有在班级表中?
  2. 比如一个年级只开了26个班,但是在上课的学生里面竟然有27班的学生(这个班目前并不存在),这很明显是有问题的。


因为此时两张表在业务上是有相关性的,但是在业务上没有建立约束关系,那么就可能出现问题。


解决方案就是通过外键完成的。建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。
 

通过使用外键约束,可以确保表之间的关联关系,并保持数据的完整性。它可以防止插入无效的引用数据或导致不一致的数据。外键约束是维护表之间关系的重要工具,并有助于确保关联数据的一致性。


总结

以上便是关于mysql表的约束的全部内容了。接下来,简单的回顾下本文内容!!!

  1. 在 MySQL 中,表的约束用于定义和保护数据的完整性和一致性。
  2. 这些约束可以在创建表时指定,也可以使用 alter table 语句添加、修改或删除;
  3. 它们帮助确保表中的数据满足特定的规则和关联条件,提供了数据的一致性和完整性保证;
  4. 根据实际需求和数据模型设计,可以结合使用不同类型的约束来实现所需的业务逻辑和数据限制。

到此,关于本文便讲解完毕了。感谢大家的观看与支持!!!

 

相关文章:

【mysql】—— 表的约束

目录 序言 (一)空属性 (二)默认值 (三)列描述 (四)zerofill (五)主键 (六)自增长 (七)唯一键 &#…...

jeecgboot 登录成功默认其他路由

util.js...

【1572. 矩阵对角线元素的和】

来源:力扣(LeetCode) 描述: 给你一个正方形矩阵 mat,请你返回矩阵对角线元素的和。 请你返回在矩阵主对角线上的元素和副对角线上且不在主对角线上元素的和。 示例 1: 输入:mat [[1,2,3]…...

GaussDB 开发篇+Java调用JDBC访问openGauss数据库

★ 数据库信息 ✔ 数据库版本:openGauss 5.0.0 ✔ 数据库端口:5432 ✔ 数据库名称:db_zzt ★ Java代码 package PAC_001;import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sq…...

钕铁硼永磁材料基本概念

目录 一、何为磁性材料二、永磁材料的主要性能三、永磁材料的历史四、永磁材料的分类五、钕铁硼永磁材料5.1 产业链5.2 生产工艺 之前也写过其他行业的一些生产过程和工艺流程,大家有兴趣的可以翻翻以前的文章。 一、何为磁性材料 参加过九年义务教育的同学应该都知…...

2005-2020年280个地级市绿色全要素生产率测算原始数据

2005-2020年280个地级市绿色全要素生产率测算原始数据 1、时间:2005-2020年 2、来源:中国城市统计年鉴、中国区域统计年鉴、中国能源年鉴、中国环境年鉴等 3、范围:280个地级市 4、指标:年末单位从业人员数、规模以上工业企业…...

电流的测量(反馈电流表)

另一方面,反馈电流表使用不同的方法来产生电流测量(见图 3)。他们使用有源跨阻放大器将电流转换为电压读数。电压输出是电流输入的倒数乘以反馈电阻器 R F的值。 V输出 -I输入* R F 图 3. 反馈电流表方法使用有源跨阻放大器将电流转换为…...

白帽黑帽与linux安全操作

目录 白帽黑帽 Linux安全 白帽黑帽 白帽(White Hat)和黑帽(Black Hat)通常用于描述计算机安全领域中的两种不同角色。白帽黑客通常被认为是合法的安全专家,他们通过合法途径寻找和修复安全漏洞,帮助企业和…...

【TypeScript】进阶之路语法细节,类型和函数

进阶之路 类型别名(type)的使用接口(interface)的声明的使用二者区别: 联合类型和交叉类型联合类型交叉类型 类型断言获取DOM元素 非空类型断言字面量类型的使用类型缩小(类型收窄)TypeScript 函数类型函数类型表达式内部规则检测函数的调用签…...

每日一题 611有效三角形的个数(相向双指针)

题目 给定一个包含非负整数的数组 nums ,返回其中可以组成三角形三条边的三元组个数。 示例 1: 输入: nums [2,2,3,4] 输出: 3 解释:有效的组合是: 2,3,4 (使用第一个 2) 2,3,4 (使用第二个 2) 2,2,3示例 2: 输入: nums [4,2,3,4] 输出: 4 题解 class Solu…...

Flink源码之JobMaster启动流程

Flink中Graph转换流程如下: Flink Job提交时各种类型Graph转换流程中,JobGraph是Client端形成StreamGraph后经过Operator Chain优化后形成的,然后提交给JobManager的Restserver,最终转发给JobManager的Dispatcher处理。 Completa…...

C#,数值计算——抛物线插值与Brent方法(Parabolic Interpolation and Brent‘s Method)的计算方法与源程序

using System; namespace Legalsoft.Truffer { /// <summary> /// 抛物线插值与Brent方法 /// Parabolic Interpolation and Brents Method /// </summary> public class Brent : Bracketmethod { public double xmin { get; set…...

基于Selenium技术方案的爬取界面内容实践

1. 定位页面&#xff08;多窗口切换&#xff09; WebDriver提供了处理多个窗口的能力&#xff0c;这是通过使用“WebDriver.switchTo.window()”方法来切换到已知名称的窗口来实现的。如果名称未知&#xff0c;您可以使用“WebDriver.getWindowHandles()”获取已知窗口列表。您…...

线程记录(1)

创建线程&#xff1a; 一、1.继承Thread&#xff0c;重写run()&#xff0c;将操作写入其中 2.创建子类对象&#xff0c;start() 二、1.实现runnable接口&#xff0c;实现run() 2.创建子类对象&#xff0c;将子类对象作为参数传递到thread的构造器中&#xff0c;创建出Thread类…...

requests

操作步骤 安装 requests 发送GET请求 发送POST请求 说明&#xff1a; data: 参数接收form表单数据&#xff0c;后台会⾃动附加form表单请求信息头&#xff08;data数据格式为字典&#xff09; json:参数接收json数据&#xff0c;后台会⾃动附加json表单请求信息头&…...

Python 监控 Windows 服务

Python 监控 Windows 服务 Python 在 Windows 系统上可以使用 wmi 模块来实现对 Windows 服务的监控。本文将介绍如何使用 Python 监控 Windows 服务&#xff0c;并实现服务状态的查询和服务启停功能。 安装依赖 在使用 wmi 模块之前&#xff0c;需要先安装 wmi包。可以使用…...

ELK中grok插件、mutate插件、multiline插件、date插件的相关配置

目录 一、grok 正则捕获插件 自定义表达式调用 二、mutate 数据修改插件 示例&#xff1a; ●将字段old_field重命名为new_field ●添加字段 ●将字段删除 ●将filedName1字段数据类型转换成string类型&#xff0c;filedName2字段数据类型转换成float类型 ●将filedNam…...

【C#】静默安装、SQL SERVER静默安装等

可以通过cmd命令行来执行&#xff0c;也可以通过代码来执行&#xff0c;一般都需要管理员权限运行 代码 /// <summary>/// 静默安装/// </summary>/// <param name"fileName">安装文件路径</param>/// <param name"arguments"…...

在vue3中定义组件的5种方式

在vue3中定义组件的5种方式 Vue 正在不断发展&#xff0c;目前在 Vue3 中定义组件的方法有多种。从选项式到组合式再到类API&#xff0c;情况截然不同。本文将会定义一个简单的组件并使用所有可用的方法重构它。 选项式 这是在 Vue 中声明组件的最常见方法。从 Vue1 就开始存…...

算法训练营题目,忘了第几天了

144. 二叉树的前序遍历 给你二叉树的根节点 root &#xff0c;返回它节点值的 前序 遍历。 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,2,3] var res[]int func preorderTraversal(root *TreeNode) []int {res []int{}traval(root)return res }func traval(no…...

数据库优化实战分享:高频场景下的性能调优技巧与案例解析

在实际开发与生产运维中&#xff0c;数据库的性能瓶颈往往是影响系统响应速度和用户体验的关键因素。尤其是在高并发访问、海量数据处理、复杂查询逻辑等高频场景下&#xff0c;数据库优化不仅仅是“锦上添花”&#xff0c;更是“雪中送炭”。本篇博文将结合实际项目经验&#…...

《UE5_C++多人TPS完整教程》学习笔记37 ——《P38 变量复制(Variable Replication)》

本文为B站系列教学视频 《UE5_C多人TPS完整教程》 —— 《P38 变量复制&#xff08;Variable Replication&#xff09;》 的学习笔记&#xff0c;该系列教学视频为计算机工程师、程序员、游戏开发者、作家&#xff08;Engineer, Programmer, Game Developer, Author&#xff09…...

短视频矩阵SaaS系统:开源部署与核心功能架构指南

一、系统架构概述 短视频矩阵系统是基于SaaS&#xff08;软件即服务&#xff09;模式的多平台内容管理解决方案&#xff0c;通过开源技术实现账号聚合、智能创作、跨平台分发及数据闭环。系统采用微服务架构&#xff0c;支持高并发场景下的弹性扩展。 二、核心功能模块开发逻辑…...

Python爬虫实战:研究urlparse库相关技术

1 引言 1.1 研究背景与意义 网络爬虫作为互联网数据采集的核心技术,在信息检索、舆情分析、数据挖掘等领域具有广泛应用。随着 Web 技术的发展,现代网站 URL 结构日益复杂,包含路径参数、查询参数、锚点等多种组件,且存在相对路径、URL 编码等问题,给爬虫开发带来了挑战…...

Linux_T(Sticky Bit)粘滞位详解

Linux 粘滞位&#xff08;Sticky Bit&#xff09;详解 一、什么是粘滞位&#xff08;Sticky Bit&#xff09; 粘滞位&#xff08;Sticky Bit&#xff09;是 Linux 和 Unix 系统中一种特殊的权限设置&#xff0c;主要应用于目录&#xff0c;其作用是在多人共享访问的目录中&am…...

青少年编程与数学 02-020 C#程序设计基础 17课题、WEB与移动开发

青少年编程与数学 02-020 C#程序设计基础 17课题、WEB与移动开发 一、C#语言Web和移动项目开发1. Web项目开发2. 移动项目开发 二、ASP.NET Core1. ASP.NET Core 基础架构1.1 请求处理管道1.2 主机模型1.3 服务器选项 2. 核心新特性2.1 NativeAOT 支持2.2 增强的身份验证方案2.…...

gitlab rss订阅失败

问题&#xff1a;gitlab rss订阅失败 处理&#xff1a;http://gitlab.com/dashboard/projects.atom?feed_tokenXXXXXXX 这个XXX要改成用户设置里的Feed令牌 推荐本地rss订阅器&#xff1a;GitHub - yang991178/fluent-reader: Modern desktop RSS reader built with Electro…...

LeetCode 高频 SQL 50 题(基础版) 之 【高级查询和连接】· 上

题目&#xff1a;1731. 每位经理的下属员工数量 题解&#xff1a; select employee_id,name,reports_count,average_age from Employees t1,(select reports_to,count(*) reports_count,round(avg(age)) average_agefrom Employeeswhere reports_to is not nullgroup by repor…...

Halcon光度立体法

1、光度立体法&#xff0c;可用于将对象的三维形状与其二维纹理&#xff08;例如打印图像&#xff09;分离。需要用不同方向而且已知照明方向的多个光源&#xff0c;拍摄同一物体的至少三张图像。请注意&#xff0c;所有图像的相机视角必须相同。 物体的三维形状主要被计算为三…...

Appium+python自动化(九)- 定位元素工具

简介 环境搭建好了&#xff0c;其他方面的知识也准备的差不多了&#xff0c;那么就开始下一步元素定位&#xff0c;元素定位主要介绍如何使用uiautomatorviewer&#xff0c;通过定位到页面上的元素&#xff0c;然后进行相应的点击等操作. 此外在介绍另一款工具&#xff1a;Insp…...