【Hello mysql】 mysql的约束

Mysql专栏:@Mysql
本篇博客简介:介绍mysql的约束

mysql的约束

    • 表的约束
    • 空属性
    • 默认值
    • 列描述
    • zerofill
    • 主键
    • 自增长
    • 唯一键
    • 外键
    • 总结

表的约束

为什么要有约束?

我们在收集一些数据的时候会要求该数据必须存在

比如说像是国家在登记公民信息的时候身份证一栏是必须要填写的不能为空

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

表的约束很多,这里主要介绍如下几个: null/not null,default, comment, zerofill,primary
key,auto_increment,unique key 。

空属性

数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算

所以说对于一些属性我们要设置为非空

语法

not null

实例

我们这里创建一个班级表 其中包含班级名和所在的教室

在外面正常的逻辑中 班级和教室都是不能为空的

  • 如果班级名为空我们就不知道自己在哪个班
  • 如果教室为空我们就不知道自己在哪个教室

所以说我们在设计数据表的时候加上非空约束

在这里插入图片描述

默认值

默认值:某一种数据会经常性的出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,
用户可以选择性的使用默认值。

语法

default xxx

在这里插入图片描述

我们插入一个数据尝试

在这里插入图片描述

我们这里只插入了值zhangsna但是age和sex都自动填写了

有了default之后还需要设置非空嘛?

不需要 因为如果我们没有填值的话 系统会给我们填上默认值 所以说就不存在空值的情况了

列描述

列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA来进行了解。

语法

comment ‘xxx’

此外我们可以通过查看创建语句来看到对于每个列的描述

实例

在这里插入图片描述

zerofill

刚开始学习数据库时,很多人对数字类型后面的长度很迷茫

比如说在下图中 int类型后面的11是什么意思呢?

在这里插入图片描述

整型不是4字节码?这个10又代表什么呢?其实没有zerofill这个属性,括号内的数字是毫无意义的

此时我们修改t8中age类型的属性 在后面加上zerofill

在这里插入图片描述

此时我们发现age的18前面补上了三个0

也就是说zerofill的意义其实是看该类型有没有达到指定的位数 如果没有达到就在前面加上0填充

主键

主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型。

语法

primary key

实例

我们创建一张表 id作为主键 name作为非空列

在这里插入图片描述

主键约束

主键中的值不能重复 一旦重复就会报错 下面是示例

在这里插入图片描述

我们可以看到插入重复id时sql直接报错了

删除主键

语法

alter table 表名 drop primary key;

在这里插入图片描述

添加主键

语法

alter table 表名 add primary key(字段列表)

在这里插入图片描述

复合主键

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

比如说在创建学生的课程表的时候学生id和课程号都是可以重复的 但是学生id和课程号的组合确是不能重复的 所以说我们要将他们设置为复合主键

语法

primary key(xxx , yyy)

在这里插入图片描述

自增长

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

自增长的特点:

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

关于索引是什么概念 我们后面的博客会讲解

语法:

auto_increment

下面是实例

在这里插入图片描述

我们开始插入名字 之后查看id的变化情况

在这里插入图片描述

我们发现id数据是从1开始依次往后递增

那么如果我们现在插入一个id为1000的数据之后的id会如何变化呢?

在这里插入图片描述

我们可以发现后面的id从1001开始自增了

唯一键

在了解唯一键之前我们首先要明白一个概念

并不是因为我们选择一个属性成为了主键这个属性才具有了唯一性 而是我们选择了一个具有唯一性的属性成为了主键

也就是说除了主键之间还有很多数据也可能具有唯一性 这也就是我们唯一键出现的原因

语法

unique

下面是实例

在这里插入图片描述

当一个数据成为唯一键之后那么这个数据就不能重复了

外键

外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。

当定义外键后,要求外键列数据必须在主表的主键列存在或为null

我们先来看最后一句加粗的话 也就是说主表中必须有数据从表中才能插入数据

语法:

foreign key (class_id) references myclass(id)

下面是实例 我们先创建主表 之后再从表中创建外键约束

在这里插入图片描述

在这里插入图片描述

我们首先像从表中插入数据尝试

在这里插入图片描述

我们可以发现主表中如果没有插入数据从表中是不能插入的

在这里插入图片描述

而主表中有数据 从表中就可以插入数据了

在这里插入图片描述
而我们删除数据的时候必须要先删除从表中的数据才能删除主表

这里总结下

  • 外键是在从表中定义的
  • 从表添加数据必须主表先添加
  • 主表删除数据必须从表先删除

我们如何理解外键约束

首先这是一种约束 它肯定是为了防止我们做出错误或不符合逻辑的操作的

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

但是实际过程中由于可能会由于人为操作的失误而造成一些错误 比如说一些数据只有学生表中有 而不存在于班级表中(这样就不知道这个学生在哪个班了)

所以说我们添加外键约束是必须的 它的本质其实就是将插入和删除数据的合法性交给mysql去审核

总结

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ESP32开发板引脚介绍【附有引脚使用实例】

ESP32开发板引脚介绍 文章目录 ESP32开发板引脚介绍👨‍🏫内容1:背景👨‍⚖️内容2:限制类引脚👨‍💻内容3:ESP32 周边设备🍉文末备注 👨‍🏫 &am…

webpack的打包流程

webpack的打包流程 yarn build 开始都走了哪些流程 yarn build 开始都走了哪些流程

ROS中bag的录制、播放和使用

文章目录 前言一、bag录制二、bag信息查看三、bag播放四、bag的使用(以A-LOAM为例) 前言 传感器获取到的信息,有时我们可能需要实时处理,有时可能只是采集数据,事后分析,比如: 机器人导航实现中&#xff0…

【雕爷学编程】Arduino动手做(138)---64位WS2812点阵屏模块5

37款传感器与执行器的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止这37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的&am…

openssl源码编译输出库-guidance-傻瓜式教程

目标: 下载openssl源码 编译输出目标版本,例如使用Android NDK编译输出Android使用的32位的库 1、下载源码 git clone https://github.com/openssl/openssl.git -b openssl-3.0.9 2、 请下载Linux版本的Android NDK 请下载Linux版本的Android NDK, 并完…

CUDA11.1、cuDNN8.6.0、Tensorrt8.5.3,ubuntu20.04安装过程记录

CUD11.1 下载地址:CUDA Toolkit Archive | NVIDIA Developer 安装: wget https://developer.download.nvidia.com/compute/cuda/11.1.1/local_installers/cuda_11.1.1_455.32.00_linux.run sudo sh cuda_11.1.1_455.32.00_linux.run 对于不是sudo用户&…

46.声明类关键字 var new funcion let const

目录 1 var 2 new 3 function 4 let 4.1 let不能在同一作用域下重复声明 4.2 let无法进行变量提升 4.3 var的变量会跑出当前作用域,但是let不会 4.4 let与var的循环定时器问题 5 const 5.1 简单值 5.2 复杂值 1 var 使用var只能让函数内部使用…

融合ELO机制的销售能力评估方案

ELO排位赛算法 文章目录 ELO排位赛算法一. ELO机制二. 销售能力抽象为ELO排位赛设计2.1 基础设计2.2 存在问题 三. 优化措施3.1 如何解决新销售存在冷启动问题新老人动态K值调整假设检验衡量赢的程度 3.2 如何解决转化率存在不置信的问题ELO升级为MultiELO 一. ELO机制 ELO等级…

C语言结构体

一、结构体的定义: 结构体(Struct)是C语言中的一个重要数据类型,它可以用来存储多个不同类型的变量。结构体类似于一个自定义的数据类型,可以包含多个不同类型的成员变量,每个成员变量可以有自己的数据类型…

sqlite3交叉编译

1、交叉编译sqllite3可以先从官网下载最新最新的源码进行编译。sqlite3下载sqlite3有两种版本的源代码,sqlite-amalgamation-3420000.zip这种是将所有的操作放到sqlite3中进行使用的。虽然官方推荐使用这种方法。但是对于嵌入式移植还是使用sqlite-autoconf-3420000…

WebGPU实战3D电商

在过去的几年里,我们一直在为 WebGPU 编写新版本的 Babylon.js 引擎。 随着下一代 Web 3D 即将在Chrome 102~103版本上公开WebGPU 1.0 ,人们的兴奋情绪与日俱增。 在这篇博文中,我将快速概述这个新的 Babylon.js WebGPU 引擎,并将…

go 爬虫速度控制

go 爬虫速度控制 使用go语言用原生net/http写爬虫如何优雅的控制并发和请求速度控制并发限流并发和限流的区别简单说明有了并发控制为什么还要限流 最总代码 使用go语言用原生net/http写爬虫如何优雅的控制并发和请求速度 go程序的执行效率相对python要快的多,且占…