MySQL之约束

MySQL之约束

注:本文是以Windos MySQL v8.0.25进行讲解

1.约束分类

概念: 对表中的数据进行限定,保证数据的正确性、有效性和完整性。
比如一个人必须有姓名,姓名不能为空
分类:
1. 主键约束primary key:用于控件字段内容不能重复,但它在一个表只允许出现一个。
2. 非空约束not null:用于控制字段的内容一定不能为空(NULL)。
3. 唯一约束unique:控件字段内容不能重复,一个表允许有多个 Unique 约束。
4. 外键约束foreign key:用于预防破坏表之间连接的动作,也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。
5. CHECK: 用于控制字段的值范围

image-20220113192730669

2.演示(非空约束not null)

非空约束:not null,某一列的值不能为null

--添加非空约束第一种方式:创建表时添加非空约束
		CREATE TABLE per(
			id INT,
			NAME VARCHAR(20) NOT NULL -- name为非空
		);
--添加非空约束第二种方式:创建表完后才添加非空约束
		ALTER TABLE per MODIFY NAME VARCHAR(20) NOT NULL;-- 注:modify的意思是更改、修改的意思

--删除name的非空约束
		ALTER TABLE per MODIFY NAME VARCHAR(20);

image-20220113194502928

image-20220228105216482

image-20220228110527404

image-20220113194521392

image-20220113194838964

image-20220113200108685

image-20220113200204430

image-20220113200252636

image-20220113200349945

image-20220113200426063

3.演示(唯一约束unique)

唯一约束:unique,某一列的值不能重复
注: 唯一约束可以有多个NULL值

--添加唯一约束第一种方式:在创建表时,添加唯一约束
		CREATE TABLE per(
			id INT,
			phone_number VARCHAR(20) UNIQUE -- 手机号
		);
--添加唯一约束第二种方式:在表创建完后,添加唯一约束
		ALTER TABLE per MODIFY phone_number VARCHAR(20) UNIQUE;	

--删除唯一约束
		ALTER TABLE per DROP INDEX phone_number; -- 删除方式的语法比较特殊

image-20220113200607915

image-20220228111005283

Key_name默认是与列名一样

image-20220228111030730

image-20220228110715495

image-20220113201159758

image-20220113201343320

image-20220113201448629

image-20220113201902868

4.演示(主键约束primary key)

主键约束:primary key。
1.含义:主键是唯一的,只能有一个;主键不能是null
2.一张表只能有一个字段为主键
3.主键就是表中记录的唯一标识
4.主键里的值不能重复

--添加主键约束第一种方式:在创建表时添加主键约束
		create table per(
			id int primary key,-- 给id添加主键约束
			name varchar(20)s
		);
--添加主键约束第二种方式:创建完表后,添加主键
		ALTER TABLE per MODIFY id INT PRIMARY KEY;
--删除主键:
		ALTER TABLE per DROP PRIMARY KEY;--注:删除主键后,id仍然不能为null

image-20220113203602348

image-20220115143952764

Key_name不默认与列名一样,取了PRIMARY

image-20220228111157385

image-20220228111215022

image-20220113203613327

image-20220113203644569

image-20220113203733148

image-20220113203847775

image-20220115144137427

image-20220113204131967

image-20220113204248820

image-20220113204259015
image-20220113204324225

6.演示(主键约束primary key自动增长)

自动增长:
概念:自动增长与主键约束关系很大;
如果某一列是数值类型的,使用 auto_increment 可以来完成值得自动增长


--添加自动增长第一种方式:在创建表时,添加主键约束,并且完成主键自增长
		create table per(
			id int primary key auto_increment,-- 给id添加主键约束
			name varchar(20)
		);
--添加自动增长第二种方式: 添加自动增长
		ALTER TABLE per MODIFY id INT AUTO_INCREMENT;
--删除自动增长
		ALTER TABLE per MODIFY id INT;--注:删除完自动增长后,主键仍然后还在

image-20220113205102033

image-20220115144517443

查看index后发现与没有自动增长的index表一样

image-20220228111605877

image-20220228111624500

image-20220113205129597

image-20220113205200391

image-20220113205240785

image-20220113205413626

image-20220115144602105

7.演示(外键约束前言)

发现以下:部门与 城市里的数据过于重复了,即数据有冗余现象,在添加或者删除的时候不方便
解决方法:创建两张表, 员工表与部门表

CREATE TABLE emp (
id INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(30),
age INT,
dep_name VARCHAR(30),
dep_location VARCHAR(30)
);-- 添加数据
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('张三', 20, '研发部', '广州');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('李四', 21, '研发部', '广州');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('王五', 20, '研发部', '广州');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('老王', 20, '销售部', '深圳');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('大王', 22, '销售部', '深圳');
INSERT INTO emp (NAME, age, dep_name, dep_location) VALUES ('小王', 18, '销售部', '深圳');

image-20220113210156112

创建以下两张表后发现仍有问题:如果在department表里把研发部删除后,employee里的员工又何去何从

create table department(
id int primary key auto_increment,
dep_name varchar(20),
dep_location varchar(20)
);

create table employee(
id int primary key auto_increment,
name varchar(20),
age int,
dep_id int -- 外键对应主表的主键
);

insert into department values(null, '研发部','广州'),(null, '销售部', '深圳');
select * from department;
INSERT INTO employee (NAME, age, dep_id) VALUES ('张三', 20, 1);
INSERT INTO employee (NAME, age, dep_id) VALUES ('李四', 21, 1);
INSERT INTO employee (NAME, age, dep_id) VALUES ('王五', 20, 1);
INSERT INTO employee (NAME, age, dep_id) VALUES ('老王', 20, 2);
INSERT INTO employee (NAME, age, dep_id) VALUES ('大王', 22, 2);
INSERT INTO employee (NAME, age, dep_id) VALUES ('小王', 18, 2);
select * from employee;

image-20220113214718627

image-20220113215600048

8.演示(外键约束primary key)

外键约束:foreign key,让表于表产生关系,从而保证数据的正确性。

--添加外键约束第一种方式:在创建表时,可以添加外键
			create table 表名(
				....
				外键列
				constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称)
			);
			 --注意:“外键名称”自己可以随便起名,constraint是限定与约束的意思
			      	
 --添加外键约束第二种方式:创建表之后,添加外键
  ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);
      --删除外键:
		ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
	--注:有外键存在的时候必须得先删除employee,然后再删department,这样才能把两个表都给删了;如果先删除department表再删除employee表格的话则会失败
--忘记外键名称的查看方法:
show create table employee;
create table department(
id int primary key auto_increment,
dep_name varchar(20),
dep_location varchar(20)
);

create table employee(
id int primary key auto_increment,
name varchar(20),
age int,
dep_id int ,
constraint emp_dept_fk foreign key (dep_id) references department(id)
);

insert into department values(null, '研发部','广州'),(null, '销售部', '深圳');
select * from department;
INSERT INTO employee (NAME, age, dep_id) VALUES ('张三', 20, 1);
INSERT INTO employee (NAME, age, dep_id) VALUES ('李四', 21, 1);
INSERT INTO employee (NAME, age, dep_id) VALUES ('王五', 20, 1);
INSERT INTO employee (NAME, age, dep_id) VALUES ('老王', 20, 2);
INSERT INTO employee (NAME, age, dep_id) VALUES ('大王', 22, 2);
INSERT INTO employee (NAME, age, dep_id) VALUES ('小王', 18, 2);
select * from employee;

show create table employee;
alter table employee drop foreign key emp_dept_fk;

alter table employee add constraint emp_dept_fk foreign key (dep_id) references department(id);

image-20220114080954331

image-20220114081021038

image-20220115145751993

image-20220228112335948

image-20220228112348785

image-20220228112405699

image-20220228112437589

image-20220115150043732

image-20220113221513200

image-20220114080539663

image-20220114081427118

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uojc8u4i-1649315769592)(../../AppData/Roaming/Typora/typora-user-images/image-20220114085502347.png)]

在这里插入图片描述

9.演示(传统级联更新)

可以进行改值

image-20220114082842944

image-20220114082855996

但是不能改id

image-20220115151530192

注:如果真的想该动值的话必须得现将值置为空,然后再进行修改

image-20220114090843651

image-20220114090911838

image-20220114091154712

image-20220114091344489

10.高级(传统级联更新)

		--添加级联操作语法:
			ALTER TABLE 表名 ADD CONSTRAINT 外键名称  FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称) ON UPDATE CASCADE ON DELETE CASCADE  ;
		
			--级联更新:
			ON UPDATE CASCADE 
         --级联删除:
         ON DELETE CASCADE 
alter table employee add constraint emp_dept_fk foreign key (dep_id) references department(id) on update cascade;

alter table employee add constraint emp_dept_fk foreign key (dep_id) references department(id) on update cascade on delete cascade;

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MR3dGdFr-1649316339766)(…/…/AppData/Roaming/Typora/typora-user-images/image-20220114091934563.png)]

image-20220114092531156

image-20220114092558194

image-20220114093132627

image-20220114093117871

image-20220114093150765
在这里插入图片描述

11.多表之间的关系分类

一对一关系实现

一对多关系实现

多对多关系实现

多表之间的关系
1. 分类:
1. 一对一(了解):
* 如:人和身份证
* 分析:一个人只有一个身份证,一个身份证只能对应一个人
2. 一对多(多对一):
* 如:部门和员工
* 分析:一个部门有多个员工,一个员工只能对应一个部门
3. 多对多:
* 如:学生和课程
* 分析:一个学生可以选择很多门课程,一个课程也可以被很多学生选择
2. 实现关系:
1. 一对多(多对一):
* 如:部门和员工
* 实现方式:在多的一方建立外键,指向一的一方的主键。
2. 多对多:
* 如:学生和课程
* 实现方式:多对多关系实现需要借助第三张中间表。中间表至少包含两个字段,这两个字段作为第三张表的外键,分别指向两张表的主键
3. 一对一(了解):
* 如:人和身份证
* 实现方式:一对一关系实现,可以在任意一方添加唯一外键指向另一方的主键。

12.演示(多表之间的关系分类)

CREATE TABLE tab_category (
			cid INT PRIMARY KEY AUTO_INCREMENT,  
			cname VARCHAR(100) NOT NULL UNIQUE
		);
				
CREATE TABLE tab_route(
			rid INT PRIMARY KEY AUTO_INCREMENT, 
			rname VARCHAR(100) NOT NULL UNIQUE,
			price DOUBLE,
			rdate DATE,
			cid INT,
			FOREIGN KEY (cid) REFERENCES tab_category(cid) #没有些定义外键名称,也就不应该写constraint ,系统会为我们自动分配一个外键名称;  tab_
		);
				
CREATE TABLE tab_user (
			uid INT PRIMARY KEY AUTO_INCREMENT,
			username VARCHAR(100) UNIQUE NOT NULL,
			PASSWORD VARCHAR(30) NOT NULL,
			NAME VARCHAR(100),
			birthday DATE,
			sex CHAR(1) DEFAULT '男',
			telephone VARCHAR(11),
			email VARCHAR(100)
		);
		
CREATE TABLE tab_favorite (
			rid INT, 
			DATE DATETIME,
			uid INT, 
			PRIMARY KEY(rid,uid), #创建复合主键,即联合主键,rid与uid合起来为tab_favorite的一个主键
			FOREIGN KEY (rid) REFERENCES tab_route(rid),
			FOREIGN KEY(uid) REFERENCES tab_user(uid)
		);

select * from  tab_category;
select * from  tab_route;
select * from  tab_user;
select * from  tab_favorite;

在这里插入图片描述
image-20220114100251031

image-20220114100457226

image-20220115161943764

image-20220115162028991

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OnIqAdkH-1649316494911)(…/…/AppData/Roaming/Typora/typora-user-images/image-20220114095215351.png)]

在这里插入图片描述

13.超键、候选键、主键、外键分别是什么

超键:在关系中能唯一标识元组的属性集称为关系模式的超键。一个属性可以为作为一个超键,多个属性组合在一起也可以作为一个超键。超键包含候选键和主键。
候选键:是最小超键,即没有冗余元素的超键。
主键:数据库表中对储存数据对象予以唯一和完整标识的数据列或属性的组合。一个数据列只能有一个主键,且主键的取值不能缺失,即不能为空值(Null)。
外键:在一个表中存在的另一个表的主键称此表的外键。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GoGo在努力

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值