标题:使用SqlServer多表连接查询,两种方法查询得出的结果为什么不一样,如题,谢 ...
只看楼主
i微尘
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2020-3-15
结帖率:50%
已结贴  问题点数:10 回复次数:2 
使用SqlServer多表连接查询,两种方法查询得出的结果为什么不一样,如题,谢谢指导~
[local]2[/local]
QQMaster数据库案例——3个表分别为QQUser记录QQ用户登录信息,BaseInfo记录QQ用户的基本信息,relation记录QQ用户的好友及黑名单信息
    relation表中——用户关系:0表示用户relationQQID是用户QQID的好友,1表示用户relationQQID是用户QQID的黑名单

目的:/* 查询QQ号码为54789625的用户的好友中每个省份的总人数,并且总人数按由大到小排序 */
        方法一(嵌套方法):select Province,count(*) from BaseInfo where QQID in (select RelationQQID from relation where QQID=54789625 and relationStatus=0) group by Province order by count(*) desc
            查询结果:
            北京市    6
            江苏省    6
            湖南省    4
            山西省    2
            陕西省    1
            天津省    1
            浙江省    1
            广西省    1
            贵州省    1
            河南省    1
            黑龙江省    1
            安徽省    1
            澳门    1
            北京    1
   
        方法二(内联接方法,):select Province,count(*) from BaseInfo join relation on BaseInfo.QQID=relation.RelationQQID where relation.QQID=54789625 and relation.relationStatus=0 group by Province order by count(*) desc
            查询结果:
            北京市    6
            江苏省    6
            湖南省    5
            山西省    2
            陕西省    1
            天津省    1
            浙江省    1
            广西省    1
            贵州省    1
            河南省    1
            黑龙江省    1
            安徽省    1
            澳门    1
            北京    1
            
        /*注意: 显示结果与方法一稍有差别,在湖南省的人数这一行比方法一数量不一致;不知道是为什么导致的,希望大神能帮解惑 */

搜索更多相关主题的帖子: 方法 用户 查询 QQ 结果 
2020-05-25 17:54
sssooosss
Rank: 9Rank: 9Rank: 9
等 级:禁止访问
威 望:3
帖 子:664
专家分:1115
注 册:2019-8-27
得分:10 
分别查询BaseInfo和relation两表内的湖南各有几个
2020-05-27 08:51
i微尘
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2020-3-15
得分:0 
回复 楼主 i微尘
select count(*) from BaseInfo where QQID in (select RelationQQID from relation where QQID=54789625 and relationStatus=0) and Province='湖南省'
/* 结果为4 */

select COUNT(*) from BaseInfo join Relation on BaseInfo.QQID=Relation.RelationQQID where Relation.QQID=54789625 and relationStatus=0 and Province='湖南省'
/* 结果为5 */

查询结果仍然不一致
2020-05-28 09:28



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-501785-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.262615 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved