MySQL多表查询

目录

一、笛卡尔积

多表查询时如果没有指定条件那么查询结果就是笛卡尔积。例如A表有2条数据,B表有4条数据,那么笛卡尔积就是2×4=8条数据。

c 复制代码
select * from a,b;

二、内连接

内连接查询的是两张表的交集部分。也就是说当表A/表B中的数据在表B/表A中没有匹配项时不会输出。

隐式内连接:select a.name, b.name from a, b where a.b_name=b.name;

显式内连接:select a.name, b.name from a inner join b on a.b_name=b.name;

二、外连接

左外连接查询的是左表所有数据+两张表的交集 。右外连接查询的是右表所有数据+两张表的交集。也就是说当表A中的数据在表B中没有匹配项时使用左外连接也会输出,当表B中的数据在表A中没有匹配项时使用右外连接也会输出。

左外连接:select a.name, b.name from a left join b on a.b_name=b.name;

右外连接:select a.name, b.name from a right join b on a.b_name=b.name;

在实际开发中,想要哪张表的所有信息就以该表作为主表。

三、自连接

自连接查询的是同一张表,例如同一张表记录了id和领导id,那么查询所有员工的信息及其领导信息就需要用自连接。自连接可以用内连接也可以用外连接,具体看需求。自连接需要对表起别名,因为需要看成两张表。

c 复制代码
select * from emp a, emp b left join on a.manager_id=b.id;

四、联合查询

联合查询可以把多次查询的结果在行上合并起来,形成一个新的结果集。

c 复制代码
select * from emp where salary>5000
union all
select * from emp where age>50

union还会将查询结果合并之后去重

五、子查询

1.列子查询

子查询返回的是1列n行数据,常用操作符:

  • in:在子查询集合内满足其一
  • not in
  • any: 在子查询集合内满足其一,一般配合>号使用
  • all:子查询集合内满足所有,一般配合>号使用

2.行子查询

子查询返回的是1行n列数据,常用操作符:

  • =
  • <>:不等于
  • in:在子查询集合内满足其一
  • not in

3.表子查询

子查询返回的是n行n列数据,常用操作符:

  • in:在子查询集合内满足其一

select * from emp where (job, salary) in (子查询select job, salary from ...)

相关推荐
IT19955 小时前
MySQL运维笔记-一种数据定期备份的方法
运维·笔记·mysql
云飞云共享云桌面5 小时前
SolidWorks服务器怎么实现研发软件多人共享、数据安全管理
java·linux·运维·服务器·数据库·自动化
Elastic 中国社区官方博客5 小时前
Elasticsearch:使用 ES|QL 与 dense_vector 字段
大数据·数据库·人工智能·sql·elasticsearch·搜索引擎·全文检索
Channing Lewis5 小时前
mysql.connector.errors.OperationalError: 1040 (08004): Too many connections
数据库·mysql·adb
数据知道5 小时前
一文掌握向量数据库Chroma的详细使用
数据库·python·向量数据库
虹科网络安全6 小时前
艾体宝洞察 | Redis vs Valkey:解决 ElastiCache 的无序扩张与资源效率问题
数据库·redis·spring
weixin_439706256 小时前
Windows MySQL的主从复制配置记录
windows·mysql·adb
xu_ws6 小时前
2G服务器优化MySQL内存配置指南
数据库·mysql
TG:@yunlaoda360 云老大6 小时前
华为云国际站代理商的ESW主要有什么作用呢?
网络·数据库·华为云