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 主表(列)

就可以设置外键约束了

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

相关推荐
C137的本贾尼1 小时前
锁的分类:表锁、行锁、页锁与意向锁
数据库
Full Stack Developme1 小时前
SQL 执行顺序 及 全部关键字
数据库·sql
专注API从业者2 小时前
电商选品效率翻倍!基于 Open Claw + 淘宝商品 API 实现自动化监控选品(附完整可运行代码)
大数据·运维·数据结构·数据库·自动化
C137的本贾尼2 小时前
InnoDB 内存架构:Buffer Pool、Change Buffer 与 Log Buffer
数据库·oracle·架构
DigitalOcean2 小时前
深度评测:RAG 向量数据库选型指南 —— OpenSearch、Weaviate、pgvector 怎么选?
数据库·ai编程
云计算磊哥@2 小时前
运维开发宝典025-MySQL01数据库的安装和配置
运维·数据库·运维开发
Bert.Cai2 小时前
SQLPlus简介
数据库·oracle
超梦dasgg2 小时前
Redis ZSet(有序集合)底层数据结构
数据结构·数据库·redis
渣渣盟2 小时前
MySQL DQL全面解析:从入门到精通
数据库·sql·mysql·dql