超详细的mysql多表操作教程

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 超详细的mysql多表操作教程

外键约束

概念

特点

定义一个外键时,需要遵守下列规则:

主表必须已经存在于数据库中,或者是当前正在创建的表。

必须为主表定义主键。

主键不能包含空值,但允许在外键中出现空值。也就是说,只要外键的每个非空值出现在指定的主键中,这 个外键的内容就是正确的。

在主表的表名后面指定列名或列名的组合。这个列或列的组合必须是主表的主键或候选键

外键中列的数目必须和主表的主键中列的数目相同。

外键中列的数据类型必须和主表主键中对应列的数据类型相同。

操作

  • 建立外键约束
1. create database  mydb3;
2. use mydb3;
3. create table if not exists dep
4. (
5. pid int primary key,
6. name varchar(20)
7. );
8. create table if not exists per
9. (
10. id int primary key,
11. name varchar(20),
12. age int,
13. depid int,
14. constraint fok foreign key(depid) references dep(pid)
15. );
16. 
17. 
18. 
19. create table if not exists dep3
20. (
21. pid int primary key,
22. name varchar(20)
23. );
24. create table if not exists per3
25. (
26. id int primary key,
27. name varchar(20),
28. age int,
29. depid int
30. );
31. alter table per3 add constraint fok3 foreign key(depid) references dep3(pid);

  • 数据插入

必须先给主表添加数据,且从表外键列的值必须依赖于主表的主键列

1. insert into dep3 values('1001','研发部');
2. insert into dep3 values('1002','销售部');
3. insert into dep3 values('1003','财务部');
4. insert into dep3 values('1004','人事部');
5. 
6. -- 给per3表添加数据
7. insert into per3 values('1','乔峰',20, '1001');
8. insert into per3 values('2','段誉',21, '1001');
9. insert into per3 values('3','虚竹',23, '1001');
10. insert into per3 values('4','阿紫',18, '1001');
11. insert into per3 values('5','扫地僧',85, '1002');
12. insert into per3 values('6','李秋水',33, '1002');
13. insert into per3 values('7','鸠摩智',50, '1002'); 
14. insert into per3 values('8','天山童姥',60, '1003');
15. insert into per3 values('9','慕容博',58, '1003');
  • 数据删除

主表数据被从表依赖时不能删除,否则可以删除;从表的数据可以随便删除。

如下,第一句和第二句执行成功,第三句执行失败

1. delete from per3 where depid=1003;
2. delete from dep3 where pid=1004;
3. delete from dep3 where pid=1002;
  • 删除外键约束

语法:alter table 从表 drop foreign key 关键词名;

alter table per3 drop foreign key fok3;

 

多表联合查询

概念

操作

  • 交叉连接查询

select * from dept,emp;
  • 内连接查询

注释;上面是隐式内连接,下面是显式内连接

1. select * from dept,emp where dept.deptno=emp.dept_id;
2. select * from dept join emp on dept.deptno=emp.dept_id;
3. 
4. select * from dept join emp on dept.deptno=emp.dept_id and name='研发部';
5. select * from dept join emp on dept.deptno=emp.dept_id and name='研发部';
6. 
7. select * from dept join emp on dept.deptno=emp.dept_id and (name='研发部' or name='销售部');
8. select * from dept join emp on dept.deptno=emp.dept_id and (name='研发部' or name ='销售部');
9. select * from dept join emp on dept.deptno=emp.dept_id and name in ('研发部','销售部');
10. 
11. select a.name,a.deptno,count(*) from dept a join emp on a.deptno=emp.dept_id group by dept_id;
12. select a.name,a.deptno,count(*) total from dept a join emp on a.deptno=emp.dept_id group by dept_id having total >=3 order by total desc;
  • 外连接查询

若是对应的外表没有数据就补NULL

1. select * from dept a left join emp b on a.deptno=b.dept_id;
2. select * from dept a right join emp b on a.deptno=b.dept_id;
3. -- select * from dept a full join emp b on a.deptno=b.dept_id; --不能执行
4. -- 用下面的方法代替上面的full join 
5. select * from dept a left join emp b on a.deptno=b.dept_id union select * from dept a right join emp b on a.deptno=b.dept_id;
6. -- 对比union all,发现union all没有去重过滤
7. select * from dept a left join emp b on a.deptno=b.dept_id union all select * from dept a right join emp b on a.deptno=b.dept_id;
  • 子查询

1. select * from emp where age<(select avg(age) from emp);
2. select * from emp a where a.dept_id in (select deptno from dept where name in ('研发部','销售部'));
3. -- 对比关联查询和子查询如下
4. select * from emp a join dept b on a.dept_id=b.deptno and (b.name='研发部' and age<30);
5. select * from (select * from dept where name='研发部') a join (select * from emp where age<30) b on b.dept_id=a.deptno;
  • 子查询关键字

all关键字的用法

1. select * from emp where age>all(select age from emp where dept_id='1003');
2. select * from emp a where a.dept_id!=all(select deptno from dept);

any(some)关键字的用法

select * from emp where age>any(select age from emp where dept_id='1003') and dept_id!='1003';

in关键字的用法

select ename,eid from emp where dept_id in (select deptno from dept where name in ('研发部','销售部'));

exists关键字的用法

1. select * from emp a where a.age<30;
2. select * from emp a where exists(select * from emp where a.age<30);
3. 
4. select * from emp a where a.dept_id in (select deptno from dept b);
5. select * from emp a where exists (select * from dept b where a.dept_id = b.deptno);
  • 自关联查询

 

多表操作总结

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
3月前
|
关系型数据库 MySQL Java
centos7安装mysql教程及Navicat平替软件
【8月更文挑战第17天】本教程详述CentOS 7上安装MySQL的过程。首先确保移除任何预装的MySQL组件,然后通过wget获取并安装MySQL的YUM源。可以选择安装特定版本如5.7或8.0。安装MySQL服务器后,启动服务并查找初始密码。登录MySQL后应立即更改密码,并可根据需要设置远程访问权限。此外,还推荐使用免费开源的DBeaver作为数据库管理工具,提供了安装步骤以方便管理和操作MySQL数据库。
148 3
|
4月前
|
SQL 运维 关系型数据库
MySQL 中 GRANT 操作会引起复制中断吗?
GRANT 操作并不是一个原子性操作,不管执行成功与否,都会触发一个隐式重载授权表的行为。 在生产环境中需要规范用户创建及授权的操作,不推荐使用 DML 语句去直接变更 mysql.user 表,可能会引发其他的问题,若使用了 DML 语句进行变更, 需要手工执行 flush privileges。
68 4
|
4月前
|
JavaScript 关系型数据库 MySQL
创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作
创建nodejs项目并接入mysql,完成用户相关的增删改查的详细操作
64 0
|
28天前
|
存储 SQL 关系型数据库
【入门级教程】MySQL:从零开始的数据库之旅
本教程面向零基础用户,采用通俗易懂的语言和丰富的示例,帮助你快速掌握MySQL的基础知识和操作技巧。内容涵盖SQL语言基础(SELECT、INSERT、UPDATE、DELETE等常用语句)、使用索引提高查询效率、存储过程等。适合学生、开发者及数据库爱好者。
40 0
【入门级教程】MySQL:从零开始的数据库之旅
|
1月前
|
tengine 关系型数据库 MySQL
Tengine、Nginx安装MySQL数据库命令教程
本指南详细介绍了在Linux系统上安装与配置MySQL数据库的步骤。首先通过下载并安装MySQL社区版本,接着启动MySQL服务,使用`systemctl start mysqld.service`命令。若启动失败,可尝试使用`sudo /etc/init.d/mysqld start`。利用`systemctl status mysqld.service`检查MySQL的服务状态,确保其处于运行中。通过日志文件获取初始密码,使用该密码登录数据库,并按要求更改初始密码以增强安全性。随后创建一个名为`tengine`的数据库,最后验证数据库创建是否成功以及完成整个设置流程。
|
3月前
|
SQL 关系型数据库 MySQL
PHP与MySQL交互之基础教程
【8月更文挑战第31天】 在数字世界中,数据是推动一切的核心力量。本文将引导你探索PHP与MySQL的协同工作,通过实际代码示例,展示如何建立连接、执行查询以及处理结果集。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你提供宝贵的实践知识。
|
3月前
|
关系型数据库 MySQL 网络安全
MySQL主从复制详细教程
配置MySQL的主从复制是一个细致的过程,需要仔细遵循上述步骤进行。一旦配置完成并运行正常,主从复制将大大提高数据库的可用性和读写性能。在操作过程中,务必保持谨慎,确保数据的一致性和安全性。
375 0
|
4月前
|
存储 关系型数据库 文件存储
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
47 2
|
4月前
|
关系型数据库 MySQL Linux
Docker安装mysql详细教程, mysqld: Can‘t read dir of ‘/etc/mysql/conf.d/‘(报错已解决)
Docker安装mysql详细教程, mysqld: Can't read dir of '/etc/mysql/conf.d/' (Errcode: 2 - No such file or directory) 已解决
|
4月前
|
SQL 关系型数据库 MySQL
实时计算 Flink版操作报错合集之从mysql读数据写到hive报错,是什么原因
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。