MySQL----约束

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 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 ;

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
NoSQL 关系型数据库 MySQL
2024Mysql And Redis基础与进阶操作系列(4-2)作者——LJS[含MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法]
24MySQL非空、唯一性、PRIMARY KEY、自增列/自增约束举例说明等详解步骤及常见报错问题对应的解决方法(4-2) 学不会你来砍我!!!
|
19天前
|
存储 SQL 关系型数据库
【MySQL基础篇】MySQL约束语法
文章介绍了MySQL中表的约束概念,包括非空、唯一、主键、默认和外键约束,以及如何在创建和修改表时指定这些约束。外键约束用于保持数据的一致性和完整性,文章通过示例展示了添加、删除外键的语法,并讨论了不同的删除/更新行为,如CASCADE和SETNULL。
【MySQL基础篇】MySQL约束语法
|
17天前
|
存储 关系型数据库 MySQL
MySQL(条件约束)
为了校验数据,让数据的正确性能够得到保证,约束,能够引进更多的检查操作,但是也会增加系统的成本开销
|
2月前
|
关系型数据库 MySQL 数据处理
MySQL函数与约束
MySQL 提供了丰富的函数和强大的约束机制,用于数据处理和完整性维护。通过掌握这些工具,可以有效地管理和分析数据库中的数据,确保数据的一致性和准确性。无论是在日常数据查询中使用内置函数,还是在数据库设计中应用各种约束,都是确保数据库系统稳定、高效运行的关键。希望本文对您理解和应用 MySQL 函数与约束有所帮助。
39 1
|
7月前
|
关系型数据库 MySQL
MYSQL-多表操作-外键约束
MYSQL-多表操作-外键约束
|
7月前
|
关系型数据库 MySQL
MYSQL:约束(主键约束)
MYSQL:约束(主键约束)
|
3月前
|
Ubuntu 关系型数据库 MySQL
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
ubuntu使用aliyun源+mysql删除有外键约束的数据+查看特定目录的大小
93 4
|
4月前
|
SQL 关系型数据库 MySQL
MySQL中外键的使用及外键约束策略
这篇文章讨论了MySQL中使用外键的重要性,包括外键的概念、不使用外键可能导致的问题、如何设置外键约束以及不同的外键约束策略(如CASCADE和SET NULL),并通过示例演示了这些概念。
MySQL中外键的使用及外键约束策略
|
4月前
|
存储 关系型数据库 MySQL
MySQL数据库基础:约束
约束是对数据库表中字段施加的规则,确保数据的正确性、有效性和完整性。主要分为非空约束、唯一约束、默认约束、主键约束和外键约束。非空约束禁止字段值为null;唯一约束确保字段值唯一,允许null值重复;默认约束设定默认值;主键约束结合非空与唯一约束,并可设为自增型;外键约束则通过关联其他表的主键,保证数据一致性。检查约束确保字段值满足特定条件。
78 1
|
5月前
|
数据采集 关系型数据库 MySQL
在 MySQL 中使用约束
【8月更文挑战第11天】
88 0
在 MySQL 中使用约束