【MySQL】表的约束

文章目录

  • [1. 空属性 null](#1. 空属性 null)
  • [2. 默认值 default](#2. 默认值 default)
  • [3. 描述 comment](#3. 描述 comment)
  • [4. zerofill](#4. zerofill)
  • [5. 主键、复合主键](#5. 主键、复合主键)
    • [5.1 主键](#5.1 主键)
    • [5.2 复合主键](#5.2 复合主键)
  • [6. 自增长 auto_increment](#6. 自增长 auto_increment)
  • [7. 唯一键 unique](#7. 唯一键 unique)
  • [8. 外键 foreign key](#8. 外键 foreign key)


在上一篇的内容中,我们学习了MySQL的数据类型,数据类型本身就是一种约束。
但是只有数据类型约束是不够的。

1. 空属性 null

  • null(默认的)
  • not null

数据库默认字段基本都是字段为空 ,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算。

设置了非空约束后,空值就无法插入进表中

2. 默认值 default

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

如果用户不指定值,但设置了默认值,则使用默认值; 未设置默认值,MySQL设置默认值为NULL。

在上面的结构中,gender一列我既设置了非空,又设置了默认值,这样有意义吗?

  • 如果一列指定了非空约束
    • 设置了默认值,用户没有明确指定插入的值,则使用default的值,插入成功;
    • 没有设置默认值,用户未明确指定插入的值,插入失败。
  • null 与默认值二者不冲突,是相互补充的
  • not null 和 defalut一般不需要同时出现,因为default本身有默认值,不会为空

3. 描述 comment

列描述:comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或数据库管理员来进行了解。

通过desc查看不到注释信息,通过show可以查看到

4. zerofill

在我们属性的类型设置为 int 类型时,编译器会默认给我们有华为 int(10),后面带数字是什么意思呢?为什么mysql会默认加上?

  • int的范围是21亿多,10位数刚好可以表示几十亿。
  • 有符号数,则默认是11位

一般我们查看时,位数是不会全显示的。若设置了 zerofill,且显示的宽度小于()中指定长度,则使用0填充。

要注意的是,这只是最后显示的结果,在MySQL中实际存储的还是原来插入的值。补0只是设置了zerofill属性后的一种格式化输出而已

5. 主键、复合主键

主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型

5.1 主键

  • 主键可以在创建表的时候直接在字段上指定主键
  • 当表创建好以后但是没有主键的时候,可以再次追加主键
  1. 建表指定主键

也可在创建表的最后指定主键

  1. 建表追加主键
  1. 删除主键

5.2 复合主键

一张表只能有一个主键,但是不意味着一个表的主键,只能添加给一列。

当主键添加给多列时,就叫做复合主键;

复合主键只要不是所有的列全都冲突,则可以添加成功。

举个例子:

学生选课时,一名学生可以选则不同的课程,但是每门课程他只能选择一次,此时就可以将学号与课程设置为复合主键,防止冲突。

在创建表的时候,在所有字段之后,使用primary key(主键字段列表)来创建主键,如果有多个字段作为主键,可以使用复合主键。


6. 自增长 auto_increment

auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作 ,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。

自增长的特点:

  • 任何一个字段要做自增长,前提是本身是一个索引(索引部分再详细讲 )
  • 自增长字段必须是整数 ,默认从1开始,也可以自己设置
  • 一张表最多只能有一个自增长

在插入后可通过 last_insert_id() 获取上次插入的 AUTO_INCREMENT 的值(批量插入获取的是第一个值)

7. 唯一键 unique

一张表中有往往有很多字段需要唯一性,数据不能重复,但是一张表中只能有一个主键 ,唯一键就可以解决表中有多个字段需要唯一性约束的问题。

唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较

唯一键和主键的区别:

主键更多的是标识唯一性的;而唯一键更多的是保证在业务上,不要和别的信息出现重复(如电话号码,学号,工号等)。

8. 外键 foreign key

外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须要有主键约束或unique约束。

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

sql 复制代码
foreign key (列名) references 主表(列名)


两张表在业务上是有相关性的,但是在业务上没有建立约束关系,那么就可能出现问题。

建立外键的本质其实就是把相关性交给mysql去审核了,提前告诉mysql表之间的约束关系,那么当用户插入不符合业务逻辑的数据的时候,mysql不允许你插入。

相关推荐
等一场春雨2 小时前
Spring Boot 3 实现 MySQL 主从数据库之间的数据同步
数据库·spring boot·mysql
小龙在山东5 小时前
memcached的基本使用
数据库·缓存·memcached
亦世凡华、6 小时前
MySQL--》快速提高查询效率:SQL语句优化技巧与实践
数据库·经验分享·sql·mysql·sql优化
不是二师兄的八戒6 小时前
深入 Redis:高级特性与最佳实践
数据库·redis·缓存
drebander7 小时前
SQL 分析函数与聚合函数的组合应用
大数据·数据库·sql
LLLuckyGirl~8 小时前
node.js之---集群(Cluster)模块
数据库
ccmjga8 小时前
Spring Boot 3 配置大全系列 —— 如何配置用户的登录与认证?
java·数据库·spring boot·后端·spring·单元测试·gradle
Dann Hiroaki8 小时前
文献分享:跨模态的最邻近查询RoarGraph
数据库·图搜索
泰山小张只吃荷园8 小时前
软件体系结构、设计模式、课程期末复习知识点全总结-SCAU
网络·数据库·sql·计算机网络·设计模式·sqlserver
JM_life9 小时前
Python入门系列之九-数据分析与可视化
数据库·python·数据分析