系统:Win10
Java:1.8.0_333
IDEA:2020.3.4
MySQL:8.0.30
Gitee:https://gitee.com/lijinjiang01/JavaWeb
1.多表查询简介
笛卡尔积:取 A,B 集合所有组合情况
多表查询:从多张表查询数据
多表查询分类:
- 连接查询
- 内连接:相当于查询 A,B 交际的数据
- 外连接:
- 左外连接:相当于查询 A 表所有数据和交集部分数据
- 右外连接:相当于查询 B 表所有数据和交集部分数据
- 子查询
2.内连接
内链接查询语法
-- 隐式内连接
SELECT 字段列表 FROM 表1,表2,... WHERE 条件;
-- 显示内连接
SELECT 字段列表 FROM 表1 [INNER] JOIN 表2 ON 条件;
内连接相当于查询 A B 交集数据
3.外连接
外连接查询语法
-- 左外连接
SELECT 字段列表 FROM 表1 LEFT [OUTER] JOIN 表2 ON 条件;
-- 右外连接
SELECT 字段列表 FROM 表1 RIGHT [OUTER] JOIN 表2 ON 条件;
左外连接:相当于查询 A 表所有数据和交集部分数据
右外连接:相当于查询 B 表所有数据和交集部分数据
4.子查询
子查询概念:
查询中嵌套查询,称嵌套查询为子查询
子查询根据结果不同,作用不同:
单行单列:作为条件值,使用 = != > < 等进行条件判断
SELECT 字段列表 FROM 表名 WHERE 字段名 = (子查询);
多行单列:作为条件值,使用 in 等关键字进行条件判断
SELECT 字段列表 FROM 表名 WHERE 字段名 IN (子查询);
多行多列:作为虚拟表
SELECT 字段列表 FROM (子查询) WHERE 条件;