MySQL表的约束(一)

真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合****法性,从业务逻辑角度保证数据的正确性。比如有一个字段是email,要求是唯一的。
表的约束很多,这里主要介绍如下几个: null/not null,default, comment, zerofill,primary
key,auto_increment,unique key,为了详细的讲述,今天这篇博客就先简绍null/not null,default, comment, zerofill这些

1.null/not null

两个值:null(默认的)和not null(不为空)
数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办
法参与运算
实践结合,我们创建一个班级表,包含班级名和班级所在的教室
站在正常的业务逻辑中:
如果班级没有名字,你不知道你在哪个班级
如果教室名字可以为空,就不知道在哪上课
所以我们在设计数据库表的时候,一定要在表中进行限制,满足上面条件的数据就不能插入到表中。这就是"约束"

实验证明,如果带了not null,就无法插入NULL,但是我们也发现,为什么选择不插入的时候还会报错呢,这个问题接下来会讲解

2.default

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

  • 预设常用值:为某个数据项提前设定一个出现频率最高的值

  • 省时省力:用户无需每次手动输入,直接接受或按需修改

  • 可覆盖:用户有最终决定权,选择使用默认值或替换为其他值

下面我们创建一个table t2,分别设置not null, default和not null default

下面我们插入数据,不难发现,默认参数会在我们不插入数据的时候自动填充

3.default 与 not null

看完上面的例子你可能会疑惑,既然有了default,那要not null有什么用,毕竟我不输入,它自动会填充default值,其实这样想就不对了,看下面的截图

说明加入了not null就无法输入null了,那么只要default难道就可以输入null了吗,答案是对的

可是为什么呢,因为在创建的时候,系统默认会给我们加上null字段(前提是也不加入default)
不过还是可以注意一下:not null和defalut一般不需要同时出现,因为default本身有默认值,不会为空

4.comment

Comment(注释)的核心

  • 说明性文本:用于解释代码逻辑、数据含义或留下提醒,不影响程序运行。

  • 被忽略执行:编译器、解释器或解析器会跳过注释,不产生任何实际指令。

  • 提升可读性:帮助他人(或未来的自己)理解复杂部分,便于维护与协作。

可以发现只有在show create table t3的时候才可以看到建立时候的comment,这就相当于一个注释,告诉我们,当时我们建立这个列的时候是干什么的

5.zerofill

刚开始学习数据库时,很多人对数字类型后面的长度很迷茫。通过show看看表的建表语句


可以看到int(10),这个代表什么意思呢?整型不是4字节码?这个10又代表什么呢?其实没有zerofill这个属性,括号内的数字是毫无意义的。a和b列就是前面插入的数据,但是对列添加了zerofill属性后,显示的结果就有所不同了


这次可以看到b的值由原来的2变成0000000002,这就是zerofill属性的作用,如果宽度小于设定的宽度(这里设置的是10),自动填充0,要注意的是,这只是最后显示的结果,在MySQL中实际存储的还是2

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

好啦,今天的表的约束就先学到这里啦,下一篇博客会简绍剩余的表的约束,不见不散哦~~

相关推荐
睡不醒男孩0308233 小时前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
Micro麦可乐5 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
码农阿豪5 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通5 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..6 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_29146 小时前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
真实的菜7 小时前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
你想考研啊7 小时前
mysql数据库导出导入
数据库·mysql·oracle
十年编程老舅8 小时前
Linux DRM:底层逻辑与实践架构
数据库·mysql
The Sheep 20238 小时前
Vue复习
linux·服务器·数据库