【SQL】MySQL中的约束

1. 主键约束(primary key):

  • 相当于唯一约束+非空约束
  • 分为单列主键,多列联合主键,一个表只有一个主键
  • 多列联合主键的每列都不能为空

2. 自增长约束(auto_increment):

  • 用在单列主键后面,且该列只能是整数类型(tinyint,smallint,int,bigint),实现主键自增长
  • delete删除数据后自动增长从断点开始,truncate删除数据后自动增长从默认起始值开始

3. 非空约束(not null):

  • 该列的值不能为空
  • 真正的空是NULL,不是'NULL',也不是''

4. 唯一约束(unique):

  • 该列的值不能重复
  • 该列可以为NULL,NULL不等于NULL,即可以有多条NULL的记录

5. 默认约束(default):

  • 指定某列的默认值,若该列没有指定值则为默认值

6. 零填充约束(zerofill)(使用非常少):

  • 插入数据时,当该字段的值长度小于定义的长度,在该值的前面补上0

7. 外键约束 - 一对多关系(foreign key):

  • 主键所在的表就是主表,外键所在的表就是从表
    添加数据:
  • 必须先给主表添加数据,再给从表添加数据
  • 外键列的值不能随便填写,必须依赖主表的主键列
    删除数据:
  • 主表的数据被从表依赖时,不能删除,否则可以删除
  • 从表的数据可以随便删除

8. 外键约束 - 多对多关系(foreign key):

  • 多对多可以拆解成两个一对多的关系

多表关系:

一对一: 很少用,因为一对一的话则可以合并成一张表
一对多/多对一: 例如学生和班级,一个班级对应多个学生
多对多: 例如学生和课程,一个学生对应多个课程,一个课程对应多个学生

相关推荐
lUie INGA5 小时前
在2023idea中如何创建SpringBoot
java·spring boot·后端
极客on之路5 小时前
mysql explain type 各个字段解释
数据库·mysql
代码雕刻家5 小时前
MySQL与SQL Server的基本指令
数据库·mysql·sqlserver
lThE ANDE5 小时前
开启mysql的binlog日志
数据库·mysql
geBR OTTE5 小时前
SpringBoot中整合ONLYOFFICE在线编辑
java·spring boot·后端
Porunarufu6 小时前
博客系统UI自动化测试报告
java
川石课堂软件测试6 小时前
软件测试:典型面试题库
数据库·python·功能测试·mysql·单元测试·grafana·prometheus
Aurorar0rua7 小时前
CS50 x 2024 Notes C - 05
java·c语言·数据结构
Lucifer三思而后行7 小时前
zCloud 纳管 MySQL 8.4 数据库
数据库·mysql·oracle
Cosmoshhhyyy7 小时前
《Effective Java》解读第49条:检查参数的有效性
java·开发语言