欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 国际 > 【MySQL】表的约束

【MySQL】表的约束

2025/1/2 12:09:38 来源:https://blog.csdn.net/weixin_69380220/article/details/144833031  浏览:    关键词:【MySQL】表的约束

文章目录

  • 1. 空属性 null
  • 2. 默认值 default
  • 3. 描述 comment
  • 4. zerofill
  • 5. 主键、复合主键
    • 5.1 主键
    • 5.2 复合主键
  • 6. 自增长 auto_increment
  • 7. 唯一键 unique
  • 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

foreign key (列名) references 主表(列名)

在这里插入图片描述
在这里插入图片描述

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

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

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com