当前位置: 首页 > news >正文

数据库(MySQL)基础:约束

一、概述

1.概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。

2.目的:保证数据库中数据的正确、有效性和完整性。

3.分类

约束描述关键字
非空约束限制该字段的数据不能为nullnot null
唯一约束保证该字段的所有数据都是唯一、不重复的unique
主键约束主键是一行数据的唯一标识,要求非空且唯一primary key
默认约束保存数据时,如果未指定该字段的值,则采用默认值default
检查约束保证字段值满足某一个条件check
外键约束用来让两张表的数据之间建立连接,保证数据的一致性和完整性foreing key

注意:约束是作用于表中字段上的,可以在创建表 / 修改表的时候添加约束。 

二、约束演示

根据需求,来完成表结构的创建

字段名字段含义 字段类型约束条件约束条件
idID唯一标识int主键,并且自动增长primary key , auto_increment
name性别varchar(10)不为空,并且唯一not null , unique
age年龄int大于0,并且小于等于120check
status状态char(1)如果没有指定该值,默认为1default
gender性别char(1)

大家不妨先自己动手尝试尝试,我就先把答案放在下方啦! 

create table if not exists user(id int primary key auto_increment comment '主键',name varchar(10) not null unique comment '姓名',age int check(age>0 && age<120) comment '年龄',status char(1) default '1' comment '状态',gender char(1) comment '性别'
)comment '用户表';

建立的表结构截图如下:

三、外键约束 

1.概念:外键用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。

注意:目前上述的两张表,在数据库层面,并未建立外键关联,所以是无法保证数据的一致性和完整性的。

在开始之前,我先来进行表结构的创建,代码如下,大家可以自行参考

create table if not exists dept(id int auto_increment comment 'ID' primary key,name varchar(50) not null comment '部门名称'
)comment '部门表';
insert into dept(name) values('研发部'),('市场部'),('财务部'),('销售部'),('总经办');
create table if not exists dept_id(id int auto_increment comment 'ID' primary key,name varchar(50) not null comment '姓名',age int comment '年龄',job char(10) comment '职位',salary int comment '薪资',entrydate date comment '入职时间',managerid int comment '直属领导ID',dept_id int comment '部门ID'
)comment '员工表';insert into emp(name,age,job,salary,entrydate,managerid,dept_id) values('金庸',66,'总裁','20000','2000-01-01',null,5),('张无忌',20,'项目经理','12500','2005-12-05',1,1),('杨逍',33,'开发','8400','2000-11-03',2,1),('韦一笑',48,'开发','11000','2002-02-05',2,1),('常遇春',43,'开发','10500','2004-09-07',3,1);

创建好的表如下:

接下来,我们来建立外键关联,以此来保证数据的一致性和完整性。

2.外键约束

2.1添加外键

create table 表名(

          字段名 数据类型 ,

          ...

          [constraint] [外键名称] foreign key (外键字段名) references 主表(主表列名)

);

alter table 表名 add constraint 外键名称 foreign key (外键字段名) references  主表(主表列名);

alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);

大家看emp表前后的区别

2.2删除外键

alter table 表名 drop foreign key 外键名称 ; 

alter table emp drop foreign key fk_emp_dept_id;

2.3删除 / 更新行为

行为说明
no action当在父表中删除 / 更新对应记录时,首先检查记录是否有对应外键,如果有则不允许删除 / 更新。(与restrict一致)
restrict当在父表中删除 / 更新对应记录时,首先检查记录是否有对应外键,如果有则不允许删除 / 更新。(与no action一致)
cascade当在父表中删除 / 更新对应记录时,首先检查记录是否有对应外键,如果有,则也删除 / 更新外键在子表中的记录。
set null当在父表中删除 / 更新对应记录时,首先检查记录是否有对应外键,如果有,则设置子表中该外键值为 null (这就要求该外键允许取 null )。
set default父表有变更时,子表将外键列设置成一个默认的值。 

alter table 表名 add constraint 外键名称 foreign key (外键字段名) references  主表名(主表列名) on update cascade on delete cascade;

 -- cascade

alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update cascade on delete cascade;

 

-- set null

alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update set null on delete set null;

 本节课的内容到此结束啦,我们下期再见!

http://www.lryc.cn/news/344931.html

相关文章:

  • ControlNet作者放大招!IC-Light:控制生成图片光照效果!
  • 【Java】Java中类的初始化顺序(静态方法,静态块,非静态块,最后有流程图)
  • 在RK3588开发板使用FFMpeg 结合云服务器加SRS实现摄像头数据推流到云端拱其他设备查看
  • elasticsearch搭建教程
  • c++ 归并排序
  • 基于vs和C#的WPF应用之动画3
  • Python import 必看技巧:打造干净利落的代码结构
  • 计算机视觉(CV)(Computer Vision)
  • python:画折线图
  • Spring Data JPA 与 MyBatisPlus的比较
  • 【C++】STL-list的使用
  • 进度条(小程序)
  • PyCharm安装教程(超详细图文教程)
  • 金蝶BI应收分析报表:关于应收,这样分析
  • salmon使用体验
  • Ubuntu 20.04 安装 Ansible
  • TypeScript学习笔记:强类型JavaScript的优雅之旅
  • 监控异地组网怎么组网?
  • 将本地托管模型与 Elastic AI Assistant 结合使用的好处
  • Linux的内核态和用户态
  • springboot利用Redis的Geo数据类型,获取附近店铺的坐标位置和距离列表
  • Vitis HLS 学习笔记--理解串流Stream(2)
  • Golang | Leetcode Golang题解之第80题删除有序数组中的重复项II
  • uniapp自定义websocket类实现socket通信、心跳检测、连接检测、重连机制
  • Hive UDTF之explode函数、Lateral View侧视图
  • 智慧公厕打造智慧城市新标杆
  • 字节发布文生图模型PuLID:高效身份ID特征定制,单张图像克隆AI虚拟分身
  • SpringBoot启动流程分析之创建SpringApplication对象(一)
  • SSH简介 特点以及作用
  • MQTT服务搭建及python使用示例