【数据库表的约束】

devtools/2024/10/19 0:20:26/

文章目录

  • 一、NULL vs ''(空字符串)
  • 二、not null 和default
  • 三、列描述字段comment
  • 四、zerofill
  • 五、primary key 主键
  • 总结


一、NULL vs ‘’(空字符串)

NULL和空字符串’’

NULL代什么都没有。
空字符串’'代有,但串是空的。

就比如:我问你有钱包吗?
NULL说:我什么都没有。
空字符串说:我有钱包,但是钱包是空的。

二、not null 和default

当想设置一个类型的约束为not null时,
1.如果用户明插入的值为NULL,就会报错。
报错原因是不能为NULL。
2.如果用户直接忽略了该项,没有插入,也会报错。
报错原因是该项没有默认值default。

所以两个报错原因是不一样的。

当设置一个性别类型的约束为not null default ‘男’。
意味着该类型插入时不能为空,且默认性别是男。
1.如果用户明插入的值为NULL,就会报错。
报错原因是不能为NULL。
2.如果用户直接忽略了该项,没有插入,不会报错,因为设置了默认值是男。

总结:not null 和default 是不冲突的,相互补充。

如果没有设置not null 约束和default约束
MySQL会自动优化,将该类型优化成default null。

在这里插入图片描述

三、列描述字段comment

这个字段可以理解成注释。

在这里插入图片描述

四、zerofill

首先创建一个的数据如下:

mysql> create table t12(
-> a int(10) unsigned not null,
-> b int(10) unsigned zerofill);

随后向中插入一些数据,如下:

mysql> insert into t12 values(1,2);
mysql> insert into t12 values(1,20);
mysql> insert into t12 values(1,200);

结果如下:
在这里插入图片描述

有了zerofill的约束后,int(10)这个字段意味着有10个字符占位,而插入的值中如果不够10位,zerofill约束会自动填充,也就是在前面补0。

注意一个细节:
在这里插入图片描述

再次建时,不给int类型设置大小,默认为什么会是11,且给10这个地方加了 unsigned zerofill后,默认是10.

int类型大小4字节,能示的范围是-2^31 ~ 2^31 - 1 ,也就是最大21亿多。
占10位,给11位的原因是还有一位示符号位。
unsigned int 类型也是4字节,示的范围是 0~2^32-1,最大42亿多,所以给10位。

总的来说,zerofill就是用来统一宽度的。
不影响存储,只影响格式化地显示。

五、primary key 主键

primary key主键的作用就是不允许中出现重复的数据。

创建

mysql> create test_key(
-> id int unsigned primary key comment ‘学号’ not null,
-> name varchar(20) not null comment ‘姓名’);

创建后,插入数据:
在这里插入图片描述
第一次插入学号为1的张飞,是可以的,但是第二次就error了。
原因是重复的id。

这是因为id号被primay key约束了,不能插入相同的id号。

但是,只要我的id不同,姓名相同,也是可以插入的。
因为姓名这个数据字段,没有被primary key 修饰。
在这里插入图片描述

primary key存在的意义是强制限制程序员不能插入相同的数据。
也就意味着插入中的数据一定是不相同的。

同时:
创建好以后但是没有主键的时候,可以再次追加主键。

alter table 名 add primary key(字段列)

删除主键

alter table 名 drop primary key;

注意:一张中最多只能有一个主键。
但是,一个主键可以被添加到多列上,叫做复合主键。

创建一个含有复合主键的格,如下:

在这里插入图片描述
插入几个数据后,再次插入(234,‘张三’)。
发现就报错了,就是复合主键约束了插入的数据不能相同。

而这个相同,是复合主键约束的数据都要相同,才形成约束
假如只有一个或一部分数据相同,也一样能插入。

在这里插入图片描述


总结

还有后续,下篇文章发布。


http://www.ppmy.cn/devtools/37535.html

相关文章

pgsql和mysql比较

pgsql相对于mysql的优势主要体现在以下几个方面: 稳定性和可靠性:PostgreSQL的稳定性极强,即使在崩溃、断电等灾难场景下也能表现出很好的抗打击能力。相比之下,很多MySQL用户都遇到过Server级的数据库丢失的情况。此外&#xff…

深入理解Java虚拟机(JVM)

引言: Java虚拟机(JVM)是Java平台的核心组件,它负责将Java字节码转换成平台特定的机器指令,并在相应的硬件和操作系统上执行。JVM的引入使得Java语言具有“一次编写,到处运行”的跨平台特性。本文将深入探…

Pyjion,一个加速程序运行python库

Pyjion,一个加速程序运行python库 Pyjion 库概述 Pyjion 是一个实验性质的 Python 库,旨在为 CPython 解释器引入即时(JIT)编译功能,以提高 Python 代码的执行性能.通过将 Python 代码编译为本机机器码,Pyjion可以加速 Python 程序的执行效率…

PHP 匿名函数和闭包在数据结构中的应用

匿名函数和闭包在数据结构处理中的应用php 中的匿名函数和闭包可用于处理数组、链表和队列等数据结构。针对数组,匿名函数可用于过滤元素;针对链表,闭包可用于创建节点;针对队列,匿名函数和闭包可实现 fifo 队列操作。…

数论:不定方程的引入

研究的对象:不定方程 文章目录 研究的对象:不定方程不定方程引入:裴蜀定理证明:欧几里得算法证明:充分性证明:必要性证明: 战术总结: 不定方程引入: 不定方程&#xff0…

3.3 Gateway之自定义过滤器

1.Gateway过滤器种类 过滤器种类描述GatewayFilter路由过滤器,作用于任意指定的路由。默认不生效,要配置到路由后生效GlobalFilter全局过滤器,作用范围是所有路由。声明后自定生效 2.Gateway过滤器参数 参数描述ServerWebExchangeGateway内…

Linux动态观测神器bpftrace的5种探针、7个常见内置变量和常见操作?

文章目录 简介5种探针内置变量:安装实操内核态:返回值:多个函数用户态if语句查看支持的观测点 其他参考 简介 bpftrace使用 LLVM 作为后端将脚本编译为 BPF 字节码,利用 BCC(BPF Compiler Collection)与 L…

IAP15W4K61S4单片机EEPROM读写程序

/*-------------关闭IAP----------------*/ void IapIdle() { IAP_CONTR 0; //关闭IAP功能 IAP_CMD 0; //清除命令寄存器 IAP_TRIG 0; …