温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

什么是Mysql联合查询

发布时间:2021-10-25 15:46:55 来源:亿速云 阅读:159 作者:iii 栏目:开发技术

这篇文章主要讲解了“什么是Mysql联合查询”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“什么是Mysql联合查询”吧!

目录
  • 联合查询之union

    • 1. 查询中国各省的ID以及省份名称

    • 2. 湖南省所有地级市ID、名字

    • 3. 用union将他们合并

  • 联合查询之union all

    • 联合查询之inner join

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

      • 2. 统计各省地级市的数量,输出省名、地级市数量

      • 3. 查询拥有20个以上区县的城市,输出城市名,区县数量

    • 联合查询之三表联合

      • 1. 区县最多的3个城市是哪个省的哪个市,查询结果包括省名,市名,区县数量

    • 联合查询之left join&right join

      • 查询所有省份和它的城市信息

      • 查询所有省份和它的城市信息和没有城市的省份信息

      • 查询所有省份和它的城市信息和没有省份的城市信息


    联合查询之union

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

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

    1. 查询中国各省的ID以及省份名称

    select ProID,ProName from T_Province

    2. 湖南省所有地级市ID、名字

    select CityID,CityName from T_City
    where ProID = (
        select ProID from T_Province where ProName="湖南省"
    );

    3. 用union将他们合并

    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

    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. 查询湖北省有多少地级市

    不用联合查询:

    select count(CityID) from T_City
    where ProID = (select ProID from T_Province where ProName="湖北省")

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

    select ProName,CityName from(
        T_City join T_Province
        on T_City.ProID = T_Province.ProID
    )
    where ProName="湖北省"

    2. 统计各省地级市的数量,输出省名、地级市数量

    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。

    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个以上区县的城市,输出城市名,区县数量

    select CityName,count(DisName) disCount from (
        T_City tc join T_District td
        on tc.CityID = td.CityID
    )
    group by CityName
    having disCount > 20;

    联合查询之三表联合

    1. 区县最多的3个城市是哪个省的哪个市,查询结果包括省名,市名,区县数量

    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.CityID
    order by ci desc
    limit 3
    )tcd
    join T_Province tp on tcd.ProID = tp.ProID;

    联合查询之left join&right join

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

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

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

    查询所有省份和它的城市信息

    select * from(
    T_Province tp join T_City tc
    on tp.ProID = tc.ProID
    );

    查询所有省份和它的城市信息和没有城市的省份信息

    select * from(
    T_Province tp left join T_City tc
    on tp.ProID = tc.ProID
    );

    查询所有省份和它的城市信息和没有省份的城市信息

    select * from(
    T_Province tp right join T_City tc
    on tp.ProID = tc.ProID
    );

    感谢各位的阅读,以上就是“什么是Mysql联合查询”的内容了,经过本文的学习后,相信大家对什么是Mysql联合查询这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI