MYSQL表的约束

表的约束

表的约束:表中一定存在各种约束,通过约束,可以让未来插入数据库中的数据是符合预期的

约束本质是通过技术手段,逼迫用户插入正确的数据

约束的最终目的就是,保证数据的完整性和可预期性

空属性

空属性表示数据是否为空

数据库默认该字段可以为空,但是实际开发时要尽量保证字段不为空

eg.

默认值

默认值:某种值需要在一开始指定好,如果没有给出值,则会使用默认值

default:缺省值,如果一开始就设置好了值,就使用开始确定的值,否则就使用缺省值定义数据

如果同时添加了not null和default

如果没有明确指定一列要插入,用的约束是default

如果建表时,对应列默认没有设置default值,则无法直接插入

default和not null不冲突,而是互补的

如果建立表时,没有指定默认值且灭有设置not null,mysql会自动添加default null

列描述

使用comment可以进行列描述,没有实际含义,本质就是编程语言中的注释

列描述是一种软性的约束

zerofill

zerofill是显示方面的约束

给特定的一列添加zerofill属性,如果显示数据的宽度小于规定宽度

则会在前面补零,让数据等宽

如果位数超过了,就不进行处理,原本是多少就是多少

主键

primary key用来唯一的约束该字段里面的数据,不能重复,不能为空

一张表最多一个主键,主键所在的列通常是整数类型

建表时一般会直接指定主键

一个表最多只有一个主键,但不意味着只有一列可以成为主键

主键可以被添加到一列或多列

此时,这两列合起来才是一个主键

必须有至少一列不同

自增长(通常和主键一起使用)

当对应的字段没有给初始值,系统会自动取当前最大值+1(如果没有值就取1)

得到一个新的值,赋值给该字段

通常和主键搭配作为逻辑主键

在primary key 后+ auto_increment

自增长字段必须是整数,且本身是一个索引

一张表最多只能有一个自增长

唯一键

唯一键可以为空,但是数据不能重复

唯一键的本质和主键差不多,但是主键不允许为空

主键更多用来表示唯一性

而唯一键则是更多的保证,在业务上,不能出现重复的信息

外键

外键用于定义主表和从表之间的关系

外键约束主要定义在从表上

主表上则必须又主键约束或unique约束

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

添加foreign key(字段名) references 主表(列)

就可以设置外键约束了

从表中不允许插入外键指定的主表的列中不存在的数据

相关推荐
唐青枫20 小时前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩20 小时前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
小满87820 小时前
5.Mysql事务隔离级别与锁机制
mysql
笃行3502 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3502 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3502 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
元Y亨H2 天前
技术笔记:MySQL 字符集排序规则与大小写敏感性问题解决方案
mysql
SelectDB2 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶3 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构