【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):

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

多表关系:

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

相关推荐
不早睡不改名@23 分钟前
Netty源码分析---Reactor线程模型深度解析(二)
java·网络·笔记·学习·netty
子非鱼@Itfuture35 分钟前
`<T> T execute(...)` 泛型方法 VS `TaskExecutor<T>` 泛型接口对比分析
java·开发语言
2601_9498161635 分钟前
spring.profiles.active和spring.profiles.include的使用及区别说明
java·后端·spring
淼淼爱喝水44 分钟前
DVWA SQL 注入(Medium/High 级别)过滤绕过与防范实验(超详细图文版)
数据库·sql·网络安全
csdn_aspnet1 小时前
MySQL主从延迟根因诊断法,从网络、IO、SQL到参数,系统化定位高并发下的同步瓶颈
数据库·mysql·主从
疯狂成瘾者1 小时前
接口规范设计:返回体 + 错误码 + 异常处理
java·状态模式
阿Y加油吧1 小时前
LeetCode 二叉搜索树双神题通关!有序数组转平衡 BST + 验证 BST,小白递归一把梭
java·算法·leetcode
项目帮1 小时前
Java毕设选题推荐:基于springboot区块链的电子病历数据共享平台设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
java·spring boot·课程设计
心有—林夕1 小时前
两个事务间的传播机制
java·事务
疯狂成瘾者1 小时前
什么是多 Agent,多Agent是如何协作的?
java