MySQL----约束

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: MySQL----约束

约束的概述

概念:

约束是作用于表中字段上的规则,用于限制存储在表中的数据

目的:

保证数据库中数据的正确、有效性和完整性

约束的分类

注意:

约束是作用在表中的字段上的,可以在创建表的时候添加,也可以在表创建之后对表的字段进行修改添加

约束案例

create table user (
    id int primary key auto_increment comment '用户id,主键',
    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
• 2
• 3
• 4
• 5
• 6
• 7

注:

约束在创建表的时候添加在每个字段后,多个约束之间用空格间隔

外键约束

外键约束概念:

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

数据准备:

创建两张表–部门表和员工表

部门表:

create table dept (
    id int auto_increment primary key comment 'id',
    name varchar(50) not null comment '部门名称'
) comment '部门表';
• 1
• 2
• 3
• 4

部门表的数据:

insert into dept (id, name) 
values (1, '研发部'), 
       (2, '市场部'), 
       (3, '财务部'), 
       (4, '销售部'), 
       (5, '总经办');
• 1
• 2
• 3
• 4
• 5
• 6

员工表:

create table emp(
    id int auto_increment primary key ,
    name varchar(50) not null ,
    age int,
    job varchar(20) comment '职位',
    salary int ,
    entrydate date comment '入职时间',
    managerid int comment '直属领导id',
    dept_id int comment '所在部门id'
) comment '员工表';
• 1
• 2
• 3
• 4
• 5
• 6
• 7
• 8
• 9
• 10

员工表数据:

insert into emp
values ( 1, '金庸', 66, '总裁', 20000, '2000-01-01', null, 5 ),
       ( 2, '张无忌', 20, '项目经理', 12500, '2005-12-05', 1, 1 ),
       ( 3, '杨晓', 33, '开发', 8400, '2000-11-03', 2, 1 ),
       ( 4, '韦一笑', 48, '开发', 11000, '2002-02-05', 2, 1 ),
       ( 5, '陈玉存', 43, '开发', 10500, '2004-09-07', 3, 1 ),
       ( 6, '小昭', 19, '程序员鼓励师', 6600, '2004-10-12', 2, 1 );
• 1
• 2
• 3
• 4
• 5
• 6
• 7

添加外键语法:

constraint 约束

create table 表名 (
  字段名 数据类型,
  ...
  constraint 外键名 foreign key (外键字段名) references 主表(主表列名)
);
alter table 表名 add constraint 外键名 foreign key (外键字段名) references 主表(主表列名);
• 1
• 2
• 3
• 4
• 5
• 6
• 7
• 8
• 9

向emp表添加外键:

alter table emp 
add constraint fk_emp_dept_id 
foreign key (dept_id) 
references dept(id);
• 1
• 2
• 3
• 4

删除外键:

语法:

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

删除emp表的外键:

alter table emp drop foreign key fk_emp_dept_id;
• 1

添加外键约束后对表的删除更新如何处理:

默认:no action

语法

直接在修改表的外键时最后添加

多个之间空格间隔

alter table 表名 
add constraint 外键名 
foreign key (外键字段名) 
references 主表(主表列名) 
on 行为 处理方式 ;
alter table 表名 
add constraint 外键名 
foreign key (外键字段名) 
references 主表(主表列名) 
on update cascade;
alter table 表名 
add constraint 外键名 
foreign key (外键字段名) 
references 主表(主表列名) 
on update cascade on delete cascade ;

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
17天前
|
关系型数据库 MySQL
MYSQL-多表操作-外键约束
MYSQL-多表操作-外键约束
|
17天前
|
关系型数据库 MySQL
MYSQL:约束(主键约束)
MYSQL:约束(主键约束)
|
4天前
|
SQL 关系型数据库 MySQL
MySQL----约束
MySQL----约束
9 1
|
12天前
|
数据采集 关系型数据库 MySQL
MySQL数据库基础第三篇(约束)
MySQL数据库基础第三篇(约束)
|
17天前
|
关系型数据库 MySQL
MYSQL约束(自增长,以及非空约束)
MYSQL约束(自增长,以及非空约束)
|
17天前
|
存储 关系型数据库 MySQL
【MySQL技术内幕】4.6-约束
【MySQL技术内幕】4.6-约束
19 1
|
24天前
|
SQL 关系型数据库 MySQL
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)一
MySQL数据库——基础篇总结(概述、SQL、函数、约束、多表查询、事务)一
26 5
|
2天前
|
SQL 关系型数据库 MySQL
MySQL外键约束行为解析:CASCADE, NO ACTION, RESTRICT, SET NULL
MySQL外键约束行为解析:CASCADE, NO ACTION, RESTRICT, SET NULL
8 0
|
27天前
|
存储 关系型数据库 MySQL
【MySQL】表的约束
【MySQL】表的约束
|
2月前
|
关系型数据库 MySQL
【MySQL进阶之路 | 基础篇】约束之CHECK约束与DEFAULT约束
【MySQL进阶之路 | 基础篇】约束之CHECK约束与DEFAULT约束