文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

【MySQL系列】表约束的学习

2023-08-16 14:11

关注

「前言」文章内容大致是MySQL的表的约束。

「归属专栏」MySQL

「主页链接」个人主页

「笔者」枫叶先生(fy)

MySQL

一、MySQL表的约束

注意:MySQL的命令对大小写不敏感的,即不区分大小写。

1.1 空属性

空值是无法参与运算,例如:

在这里插入图片描述
注意:null代表的是不存在,不是C语言、C++里面的NULL,注意区别。

例如:创建一个班级表,包含班级名和班级所在的教室

mysql> create table if not exists class(    -> class_name varchar(20),    -> class_room varchar(10));

查看表的属性,这些类型字段默认是null
在这里插入图片描述
尝试插入数据,是允许插入为空的数据的
在这里插入图片描述
站在正常的业务逻辑中:

所以我们在设计数据库表的时候,一定要在表中进行限制,不满足条件的数据就不能插入到表中。这就是“约束”。

如果要让某个字段不允许为空,在创建表的时候就可以给对应字段设置not null属性。

依旧是创建一个班级表,包含班级名和班级所在的教室,但是这两个属性不允许为空

mysql> create table if not exists class2(    -> class_name varchar(20) not null,    -> class_room varchar(10) not null);

创建表完毕后查看表结构,可以看到这两个字段是不允许为空的。
在这里插入图片描述
查看表创建时的细节
在这里插入图片描述
向表中插入数据时,只有这两个字段都不为空时才能插入成功,否则将会插入失败。
在这里插入图片描述

1.2 默认值(default)

比如,创建一个表,表当中包含用户的姓名、年龄和性别,年龄和性别分别设置为18,男

mysql> create table if not exists t1(    -> name varchar(20) not null,    -> age tinyint unsigned default 18,    -> sex char(2) default '男');

创建之后,查看表是属性
在这里插入图片描述
向表中插入数据时,如果不指明用户的年龄或性别,那么就会使用对应的默认值(缺省值)
在这里插入图片描述

还有一种就是一个字段同时设置not nulldefault两个值:

1.3 列描述(comment)

列描述comment,没有实际含义,专门用来描述字段,会根据表创建语句保存,用来给程序员或DBA来进行了解,相当于C语言、C++的注释。

比如创建一个表,表当中包含用户名、用户的年龄和用户的性别,在每一个字段后面添加上对应的列描述。

mysql> create table if not exists t2(    -> name varchar(20) not null comment '这是用户的名字',    -> age tinyint unsigned default 18 comment '这是用户的年龄',    -> sex char(1) default '男' comment '这是用户的性别');

创建之后,查看表创建时的详细信息(通过desc查看不到注释信息)

show create table t2;

在这里插入图片描述
注意:MySQL使用单引号也可以代表字符串,与C语言、C++的有区别

1.4 zerofill

数值类型后面的圆括号中的数字,代表的是显示宽度,对应数值类型设置zerofill属性后,如果数据的宽度小于设定的宽度则自动填充0

例如:创建一个表,表当中包含a和b两列整型数据,将它们的显示宽度都设置成5,但是没有设置zerofill属性

mysql> create table if not exists t3(    -> a int(5),    -> b int(5));

向表中插入一条记录,正常显示
在这里插入图片描述
修改表结构,给a列添加上zerofill属性,由于a列数据的显示宽度为5,因此查看表中数据可以看到a列数据中宽度不足5位的数据都自动在前面填充0
在这里插入图片描述
要注意的是,这只是最后显示的结果,在MySQL中实际存储的还是1,00001只是设置了zerofill属性后的一种格式化输出而已。

简单说一下索引,后序详谈

1.5 主键(primary key)

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

比如创建一个学生表,表当中包含学生的学号和姓名,由于学生的学号是不会重复的,因此可以将其设置成主键

mysql> create table if not exists student(    -> stu_id int unsigned primary key comment '学生ID',    -> stu_name varchar(20) not null comment '学生姓名');

创建表成功后查看表结构,可以看到id对应的Key列出现了PRI,PRI就是主键。
在这里插入图片描述
查看表的创建详细信息,主键也可以这样设置,图中圈起来的
在这里插入图片描述
进行插入,插入表中的记录的主键字段不能重复,如果插入记录的主键与表中已有记录的主键重复,这时就会因为主键冲突而插入失败
在这里插入图片描述

当表创建好以后但是没有主键的时候,可以再次追加主键

alter table 表名 add primary key(字段列表)

需要注意:只有列当中的值不为空并且不重复的列才能被设置成主键,如果列中已经有了重复的的值,则设置主键失败。这也说明要先把表结构设计好,不然后面插入有数据很难进行操作

删除主键

alter table 表名 drop primary key;

复合主键

比如创建一个成绩表,表当中包含学生的ID,课程ID,成绩。学生ID和课程ID可以同时设置为主键,因为这两个字段不能同时重复也不能为空。

mysql> create table if not exists t5(    -> stu_id int unsigned,    -> course char(10) comment '课程ID',    -> score tinyint unsigned default 0 comment '成绩',    -> primary key(stu_id, course) -- id和course为复合主键    -> );

注:-- 后面也是注释

查看表信息,可以看到两列都是PRI,即主键,并且它们都是不允许为空的
在这里插入图片描述
向表中插入数据时,只有插入的学生ID和课程ID同时出现冲突时才会产生主键冲突,否则就允许插入。
在这里插入图片描述
只有两个同时冲突时才会产生主键冲突,有点像C语言的&&条件
在这里插入图片描述

1.6 自增长(auto_increment)

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

自增长的特点:

比如创建一个表,表当中包含id和name,将id同时设置成主键和自增长字段

mysql>  create table if not exists t6(    -> id int unsigned auto_increment,    -> name varchar(20) not null default '',    -> primary key(id)    -> );

创建表完毕后查看表结构,可以看到id的Extra列中出现了auto_increment标志
在这里插入图片描述
向表中插入第一条记录时如果没有指明自增长字段的值,那么自增长字段的值默认将会从1开始。id不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值
在这里插入图片描述
后续向表中插入记录时如果也不指明自增长字段的值,那么自增长字段的值就会依次递增。如下:

在这里插入图片描述
插入数据的时候也可以指明自增长字段的值,此时将会使用该值进行插入,但注意指明的值不能和表中已有的id值重复。
在这里插入图片描述
继续插入,会i从d列中找出最大值,会将最大值加一后得到的值作为自增长字段的值进行插入
在这里插入图片描述
这个自增长在表外就有设置,查看表创建的详细信息就可以看到,这个值就是作为下一次自增长的值。如果想指定自增长的开始值,可以在表外面进行修改这个值。
在这里插入图片描述
输入select last_insert_id();可以查看当前值的上一个,即表中的最大一个值
在这里插入图片描述

1.7 唯一键(unique)

比如,创建一个学生表,表当中包含学生的id、姓名和电话号码,将我们选择id作为主键,但同时每个学生的电话号码也应该具有唯一性约束,因此应该将电话号码设置成唯一键。

mysql> create table if not exists t7(    -> stu_id int unsigned primary key auto_increment,    -> name varchar(20) not null,    -> tel varchar(20) unique comment '唯一键'    -> );

表创建完毕后查看表结构,可以看到tel的Key列出现了UNI标志,这就表明tel已经成功被设置成唯一键了。
在这里插入图片描述
查看表创建的详细信息
在这里插入图片描述
向表中插入数据时,如果插入记录中的电话号码与表中已有记录的电话号码出现重复,那么就会因为唯一键冲突而插入失败,还有唯一键是可以允许为空。
在这里插入图片描述

1.8 外键(foreign key)

语法:

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

比如,先创建一个班级表作为主表,表当中包含班级的id和班级名,并将班级id设置为主键。

mysql> create table if not exists class(    -> id varchar(10) primary key,    -> name varchar(20) not null    -> );

创建成功后查看表的详细信息
在这里插入图片描述

再创建一个学生表,表当中包含学生的id、姓名以及学生所在班级对应的id,学生ID设置为主键,班级ID设置为外键

mysql> create table if not exists student(    -> stu_id int unsigned primary key auto_increment,    -> name varchar(20) not null,    -> class_id varchar(20),    -> foreign key(class_id) references class(id)    -> );

表创建成功后查看表的详细信息,学生表中的班级id对应的Key列出现了MUL,这表明class_id已经成功被设置成了外键。
在这里插入图片描述
向班级表插入两条数据
在这里插入图片描述
向学生表中插入记录时,如果插入的记录对应的班级id是班级表中存在的,或者插入的班级id为null,那么此时是允许进行插入的。
在这里插入图片描述

但是如果插入学生表的记录对应的班级id是不存在,此时将会插入失败,这就是外键约束
在这里插入图片描述
这里的班级表就是主表,学生表就是从表
在这里插入图片描述
在查看学生表创建时的详细信息时,图中圈起来的,这个字段是给外键约束起名字,不过一般都不怎么使用,默认情况下外键有自己的名字,圈起来引号的内容。
在这里插入图片描述
--------------------- END ----------------------

「 作者 」 枫叶先生「 更新 」 2023.8.6「 声明 」 余之才疏学浅,故所撰文疏漏难免,          或有谬误或不准确之处,敬请读者批评指正。

来源地址:https://blog.csdn.net/m0_64280701/article/details/132122686

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯