我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySql约束超详细介绍

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

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySql约束超详细介绍

1. 什么是约束

约束对应的英语单词:constraint

在创建表的时候,我们可以给表中的字段加上一些约束,来保证表中的数据的完整性、有效性!!!

约束的作用就是为了保证:表中的数据有效!!

2. 约束包括哪些

非空约束 not null

唯一性约束 unique

主键约束 primary key

外键约束 foreign key

检查约束 check

3. 非空约束

非空约束 not null 约束的字段不能为 NULL

mysql> create table t_vip(id int, name varchar(255) not null);

MySql约束超详细介绍

mysql> insert into t_vip(id, name) values(1, 'zhangsan');
mysql> insert into t_vip(id, name) values(2, 'lisi');

MySql约束超详细介绍

mysql> insert into t_vip(id) values(3);
ERROR 1364 (HY000): Field 'name' doesn't have a default value

MySql约束超详细介绍

4. 唯一性约束

唯一性约束 unique 约束的字段不能重复,但是可以为 NULL

1. 单字段唯一性约束

mysql> create table t_vip(id int, name varchar(255) unique, email varchar(255));

MySql约束超详细介绍

mysql> insert into t_vip(id, name, email) values(3, 'lisi', 'lisi@123.com');
ERROR 1062 (23000): Duplicate entry 'lisi' for key 't_vip.name'
mysql> select * from t_vip;

MySql约束超详细介绍

2. 多字段唯一性约束

需求:name 和 email 两个字段联合起来具有唯一性!!!

mysql> create table t_vip(id int, name varchar(255) unique, email varchar(255) unique);

这样创建的表是不符合上述需求的,因为 name 具有唯一性,email 具有唯一性。两个字段各自具有唯一性。

mysql> create table t_vip(id int, name varchar(255), email varchar(255), unique(name, email));
mysql> insert into t_vip(id, name, email) values(1, 'zhangsan', 'zhangsan@123.com');
mysql> insert into t_vip(id, name, email) values(1, 'zhangsan', 'zhangsan@sina.com');

MySql约束超详细介绍

5. 主键约束

主键约束 primary key 简称 pk

1. 主键约束的相关术语

  1. 主键约束:就是一种约束。
  2. 主键字段:该字段上添加了主键约束,这样的字段叫做:主键字段。
  3. 主键值:主键字段中的每一个值都叫做:主键值。

2. 什么是主键以及有啥用

主键值是每一行记录的唯一标识

主键值是每一行记录的身份证号!!!

记住:任何一张表都应该有主键,没有主键,表无效!!!

主键的特征:not null + unique(主键值不能是 NULL,同时也不能重复)

3. 单一主键

mysql> create table t_vip(id int primary key, name varchar(255));

MySql约束超详细介绍

主键不能重复

mysql> insert into t_vip(id, name) values(2, 'lisi');
ERROR 1062 (23000): Duplicate entry '2' for key 't_vip.PRIMARY'

MySql约束超详细介绍

主键不能为NULL

mysql> insert into t_vip(name) values('lisi');
ERROR 1364 (HY000): Field 'id' doesn't have a default value

MySql约束超详细介绍

4. 复合主键

mysql> create table t_vip(id int, name varchar(255), email varchar(255), primary key(id, name));

MySql约束超详细介绍

mysql> insert into t_vip(id, name, email) values(1, 'zhangsan', 'zhansgan@123.com');
mysql> insert into t_vip(id, name, email) values(1, 'lisi', 'lisi@123.com');

MySql约束超详细介绍

5. 其他主键

除了单一主键和复合主键外,还拥有:

  • 自然主键:主键值是一个自然数,和业务没有关系。
  • 业务主键:主键值和业务紧密关联,例如拿银行卡账号做主键值。这就是业务主键!

实际开发中,使用自然主键多,很少使用业务主键!!!

主键一旦和业务值挂钩,可能会出现各种问题!!!

6. 外键约束

外键页数 foregin key 简称 fk

1. 外键约束的相关术语

  1. 外键约束:一种约束:foregin key。
  2. 外键字段:该字段上添加了外键约束。
  3. 外键值:外键字段当中的每一个值。

2. 外键出现的原因

业务背景:

请设计数据库表,来描述 “班级和学生” 的信息?

第一种方案:班级和学生存储在一张表中

MySql约束超详细介绍

分析上述方案的缺点:数据冗余,空间浪费!!!

第二种方案:班级一张表,学生一张表

MySql约束超详细介绍

MySql约束超详细介绍

当 cno 字段没有任何约束的时候,可能会导致数据无效。可能出现一个 102,但是 102 班级不存在,所以为了保证 cno 字段中的值都是 100 和 101,需要给 cno 字段添加外键约束。 那么:cno 字段就是外键字段。cno 字段中的每一个值都是外键值。

注意:

t_class 是父表 t_student 是字表

删除表的顺序?

先删子,再删父。

创建表的顺序?

先创建父,再创建子。

删除数据的顺序?

先删子,再删父。

插入数据的顺序?

先插入父,再插入子。

3. 创建外键表

创建表

mysql> create table t_class(classno int primary key, classname varchar(255));
mysql> create table t_student(no int primary key auto_increment, name varchar(255), cno int, foreign key(cno) references t_class(classno));

MySql约束超详细介绍

MySql约束超详细介绍

插入数据

mysql> insert into t_class(classno, classname) values(100, '北京市大兴区亦庄镇第二中学高三1班');
mysql> insert into t_class(classno, classname) values(101, '北京市大兴区亦庄镇第二中学高三2班');

MySql约束超详细介绍

mysql> insert into t_student(name, cno) values('jack', 100);
mysql> insert into t_student(name, cno) values('lucy', 100);
mysql> insert into t_student(name, cno) values('lilei', 100);
mysql> insert into t_student(name, cno) values('hanmeimei', 100);
mysql> insert into t_student(name, cno) values('zhangsan', 100);
mysql> insert into t_student(name, cno) values('lisi', 100);
mysql> insert into t_student(name, cno) values('wangwu', 100);
mysql> insert into t_student(name, cno) values('zhaoliu', 100);

MySql约束超详细介绍

注意:子表中的外键引用的父表中的某个字段,被引用的这个字段必须是主键吗?

不一定是主键,但至少具有 unique 约束。

到此这篇关于MySql约束超详细介绍的文章就介绍到这了,更多相关MySql约束内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

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

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

MySql约束超详细介绍

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL内部函数的超详细介绍

目录字符串函数1. length(str)2. concat(str1,str1,…)3. insert(str1,n,m,str2)4. lower(str)5. upper(str)6. left(str,n)7. rig
2022-08-08

Jetpack Compose Canvas绘制超详细介绍

Canvas 是允许您在屏幕上指定区域并在此区域上执行绘制的组件。您必须使用修饰符指定尺寸,无论是通过Modifier.size修饰符指定确切尺寸,还是通过Modifier.fillMaxSize,ColumnScope.weight等相对于父级指定精确尺寸。如果父级包装了此子级,则仅必须指定确切尺寸
2022-11-13

Phar反序列化超详细介绍

这篇文章主要为大家介绍了PHP开发技巧之PHAR反序列化详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-16

VueRouter路由守卫超详细介绍

路由守卫,简单理解来说就是,当用户要进行一些操作时,我需要用户的一些信息或数据或行为,我判断过后,才会同意用户进行操作,说到这里,我想大家心里都或多或少有点理解了吧
2023-01-28

MySQL主键约束和外键约束详解

目录1、PRIMARY KEY2、FOREIGN KEY3、表的设计3.1 一对一3.2 一对多3.3 多对多1、PRIMARY KEY上期我们讲述了 not null 和 unique 约束,而本期的第一个约束就是这俩的结合体,也成为主
2023-03-13

编程热搜

目录