多表查询
分类:
- 合并结果集(了解)
- 连接查询
- 子查询
合并结果集(上下)
- 要求被合并的结果集中,列的类型和列数相同
- UNION,去除重复行
- UNION ALL,不去除重复行
两表上下连接,共同显示
连接查询(左右)
分类
- 内连接
- 外连接
– 左外连接
– 右外连接
– 全外连接(MySQL不支持) - 自然连接(属于一种简化方式)
内连接(两表相乘-笛卡尔积)
笛卡尔积
{a, b, c} · {1,2}
{a1, a2, b1, b2, c1, c2}
- 方言(仅Mysql):SELECT * FROM 表1 别S名1
,
表2 别名2WHERE
别名1.xx=别名2.xx
- 标准(Sql数据库):SELECT * FROM 表1 别名1
INNER JOIN
表2 别名2ON
别名1.xx=别名2.xx
- 自然:SELECT * FROM 表1 别名1
NATURAL JOIN
表2 别名2 (寻找名字完全相同的列,进行自动匹配,相同的列只显示一次!)
外连接
外连接分主次,左外以左为主,右外以右为主,主表的每一项都会显示,无论是否满足条件!
当不满足条件时,次表使用null来补位!
左外连接
左外:SELECT * FROM 表1 别名1 LEFT OUTER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
左表记录无论是否满足条件都会查询出来,而右表只有满足条件才能出来。
左表中不满足条件的记录,右表部分都为NULL。
左外自然:SELECT * FROM 表1 别名1 NATURAL LEFT OUTER JOIN 表2 别名2
右外连接
右外:SELECT * FROM 表1 别名1 RIGHT OUTER JOIN 表2 别名2 ON 别名1.xx=别名2.xx
右表记录无论是否满足条件都会查询出来,而左表只有满足条件才能出来。
右表不满足条件的记录,其左表部分都为NULL。
右外自然:SELECT * FROM 表1 别名1 NATURAL RIGHT OUTER JOIN 表2 别名2
全连接
MySql不支持全连接
可以使用 UNION 来完成全链接, 左外 UNION 右外 可以得到全外连接结果!
子查询
查询中有查询(select关键字的个数大于1!)
1. 出现的位置:
- where后作为条件存在
- from后作为表存在(多行多列)
2. 条件
多行单列 : IN, ALL, ANY
单行单列:SELECT * FROM 表1 别名1 WHERE 列1 [=、>、<、>=、<=、!=] (SELECT 列 FROM 表2 别名2 WHERE 条件)
多行单列:SELECT * FROM 表1 别名1 WHERE 列1 [IN, ALL, ANY] (SELECT 列 FROM 表2 别名2 WHERE 条件)
单行多列:SELECT * FROM 表1 别名1 WHERE (列1,列2) IN (SELECT 列1, 列2 FROM 表2 别名2 WHERE 条件)
多行多列:SELECT * FROM 表1 别名1 , (SELECT ....) 别名2 WHERE 条件