前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mysql之联合查询那些事儿

Mysql之联合查询那些事儿

作者头像
Regan Yue
发布2021-09-16 10:42:42
9140
发布2021-09-16 10:42:42
举报
文章被收录于专栏:ReganYue's BlogReganYue's Blog

Mysql之联合查询那些事儿

联合查询之union

union可以合并两个以上 select语句查询出来的表,并消除表中的重复行。

其中,select语句需要拥有相同数量和相同数据类型的列。

1. 查询中国各省的ID以及省份名称
代码语言:javascript
复制
select ProID,ProName from T_Province
2. 湖南省所有地级市ID、名字
代码语言:javascript
复制
select CityID,CityName from T_City
where ProID = (
	select ProID from T_Province where ProName="湖南省"
);
3. 用union将他们合并
代码语言:javascript
复制
select ProID,ProName from T_Province
union
select CityID,CityName from T_City
where ProID = (
	select ProID from T_Province where ProName="湖南省"
);

这样就得到两个查询结果的并集了。

UNION 合并后的集合中的列名总是等于 UNION 中第一个 SELECT 语句中的列名。

联合查询之union all

代码语言:javascript
复制
select ProID,ProName from T_Province
union all
select CityID,CityName from T_City
where ProID = (
	select ProID from T_Province where ProName="湖南省"
);

当使用union all,不会消除重复行。

联合查询之inner join

1. 查询湖北省有多少地级市

不用联合查询:

代码语言:javascript
复制
select count(CityID) from T_City
where ProID = (select ProID from T_Province where ProName="湖北省")

通过ProID将两张表连接在一起

代码语言:javascript
复制
select ProName,CityName from(
	T_City join T_Province
	on T_City.ProID = T_Province.ProID
)
where ProName="湖北省"
2. 统计各省地级市的数量,输出省名、地级市数量
代码语言:javascript
复制
select T_City.ProID,ProName,count(CityID) as cc from(
	T_City join T_Province
	on T_City.ProID = T_Province.ProID
)
group by T_City.ProID
order by cc desc;

什么的select语句中要输出的ProID应该是T_City和T_Province中的一个,不然就会报错。

两个表之间需要有共同的(列名不一定相同)“语言”才能join。

可以给表起个别名,将T_City表的别名设为tc,将T_Province的别名设为tp。

代码语言:javascript
复制
select tc.ProID,ProName,count(CityID) as cc from(
	T_City tc join T_Province tp
	on T_City.ProID = T_Province.ProID
)
group by tc.ProID
order by cc desc;
3. 查询拥有20个以上区县的城市,输出城市名,区县数量
代码语言:javascript
复制
select CityName,count(DisName) disCount from (	T_City tc join T_District td    on tc.CityID = td.CityID)group by CityNamehaving disCount > 20;

联合查询之三表联合

1. 区县最多的3个城市是哪个省的哪个市,查询结果包括省名,市名,区县数量
代码语言:javascript
复制
select tp.ProName,tcd.CityName,tcd.ci from(select ProID,CityName,count(ID) ci from(T_City tc join T_District td on tc.CityID = td.CityID)     group by tc.CityIDorder by ci desclimit 3)tcdjoin T_Province tp on tcd.ProID = tp.ProID;

联合查询之left join&right join

内连接是基于左右两表公共的部分

左连接是基于左右两表公共的部分加上左表特有的部分

右连接是基于左右两表公共的部分加上右表特有的部分

查询所有省份和它的城市信息
代码语言:javascript
复制
select * from(T_Province tp join T_City tcon tp.ProID = tc.ProID);
查询所有省份和它的城市信息和没有城市的省份信息
代码语言:javascript
复制
select * from(T_Province tp left join T_City tcon tp.ProID = tc.ProID);
查询所有省份和它的城市信息和没有省份的城市信息
代码语言:javascript
复制
select * from(T_Province tp right join T_City tcon tp.ProID = tc.ProID);
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-09-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 联合查询之union
    • 1. 查询中国各省的ID以及省份名称
      • 2. 湖南省所有地级市ID、名字
        • 3. 用union将他们合并
        • 联合查询之union all
        • 联合查询之inner join
          • 1. 查询湖北省有多少地级市
            • 2. 统计各省地级市的数量,输出省名、地级市数量
              • 3. 查询拥有20个以上区县的城市,输出城市名,区县数量
              • 联合查询之三表联合
                • 1. 区县最多的3个城市是哪个省的哪个市,查询结果包括省名,市名,区县数量
                • 联合查询之left join&right join
                  • 查询所有省份和它的城市信息
                    • 查询所有省份和它的城市信息和没有城市的省份信息
                      • 查询所有省份和它的城市信息和没有省份的城市信息
                      领券
                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档