MySQL--多表查询
Posted 喵喵喵喵?
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL--多表查询相关的知识,希望对你有一定的参考价值。
多表查询
使用多表关联查询的原因:查询的数据发布在多个表里
合并结果集:
合并结果集就是把两个select语句的查询结果合并到一起,结果集就是一个表格
两种方式:
UNION:去掉重复记录
如:select * from t1 union select * from t2;
UNION ALL:不去除重复记录
如:select * from t1 union all select * from t2;
要求:被合并的两个结果:列数必须相同
内连接
语法1:
select 列名 from 表一, 表二 where 表1.列名 条件运算符 表2.列名[and 条件] [order by 排序列];
语法2:
select 列名 from 表一 inner join 表二 on 表1.列名 条件运算符 表2.列名[where 条件][order by 排序列];
语法3:
select 列名 from 表1 natural join 表2;
步骤:
- 列出查询字段
- 观察查询字段在哪些表中
- 提取各表的公共字段
- 分析条件
外连接:
左外连接:
语法:
Select 列名 from 左表 left join 右表 on 左表.列名 条件运算符 右表.列名 [where 条件][order by 排序列];
含义:
左外连接是以左表为主表,去关联右表(从表),结果集中包括主表所有数据行,如果主表的某行在从表中没有匹配时,则从表的选择列为null值
select * from 表一 别名一 natural left outer join 表2 别名2;
右外连接:
语法:
select 列名 from 左表 right join 右表 on 左表.列名 条件运算符 右表.列名 [where 条件] [order by 排序列];
含义:
右外连接是以右表为主表,去关联左表(从表),结果集中包含主表所有数据行,如果主表的某行在从表中没有匹配行时,则从表的选择列为null值
select * from 表一 别名 natural right outer join 表二 别名二;
全外连接:
语法:
select 列名 from 左表 full [outer] join 右表 on 左表.列名 条件运算符 右表.列名 [where 条件] [order by 排序列]
含义:
完全连接左表和右表中所有行,当某行数据在另一个表中没有匹配时,则另一个表的选择列值为null
子查询
概念:
子查询就是嵌套查询,即select中包含select,如果一条语句中存在两个,或两个以上select,那么就是子查询语句了
子查询出现的位置:
where后,作为条件的一部分
From后,作为被查询的一条表
子查询结果集的形式:
单行单列:select * from 表一 别名一 where 列一[=、>、<、>=、<=、!=](select 列 from 表二 别名二 where 条件);
多行单列:select * from 表一 别名一where 列一[IN,All,ANY](select 列 from 表二 别名二 where 条件);
单行多列:select * from 表一 别名一where (列一, 列二) in (select 列1, 列2 from 表2 别名2 where 条件);
多行多列:select * from 表1 别名1, (select) 别名2 where 条件;
以上是关于MySQL--多表查询的主要内容,如果未能解决你的问题,请参考以下文章