吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1149|回复: 13
收起左侧

[已解决] 【SQL基础语句】这两条语句有什么区别

[复制链接]
MyModHeaven 发表于 2023-1-20 15:45
本帖最后由 MyModHeaven 于 2023-1-20 18:07 编辑
select title, magnet from guochan group by title having count(*) > 1 order by title

结果有89条

select title, magnet from guochan where title in (select title from guochan group by title having count(*) > 1) order by title

结果有 184 条

为什么查询出来的结果不一样呢?我看着这两条语句没区别啊,问了问 ChatGPT,它也说没区别

刚接触 SQL,求指点,谢谢!







评论区的热心友友解释的,没看懂。但是我知道这两个数字之间的关系了。我的错误在于默认存在重复的记录只重复了一次。

第一条语句,89 是存在重复的记录的数量(这89条中没有互相重复的),184 是所有重复的记录的数量。经查询,89 个存在重复的记录中,大部分都是重复 1 次,4 个重复 3 次, 1 个重复 4 次。然后根据 89 计算一下,果然就是 184。(89-4-1)×2 + 4×3 + 1×4=184

但是至今我也没明白二楼说的什么意思

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

头像被屏蔽
saszznz 发表于 2023-1-20 16:09
提示: 作者被禁止或删除 内容自动屏蔽
1039468583 发表于 2023-1-20 16:18
第一段sql 采用的时group by 所以对于titile是去重的
第二段sql 用的是titile in (titile 符合要求)所以titile可能由一定的重复
故第一段代码数量相对于第二段sql较少
 楼主| MyModHeaven 发表于 2023-1-20 16:28
1039468583 发表于 2023-1-20 16:18
第一段sql 采用的时group by 所以对于titile是去重的
第二段sql 用的是titile in (titile 符合要求)所以t ...

那第一个结果的数量不应该是第二个的一半吗?

第一条语句是在title去重之后的里面,挑选出和外面重复的title,第二条语句是输出表中所有的重复title,我是这么理解的,所以二者的数量应该是二倍的关系,那为什么不是呢?哪里理解错了
1039468583 发表于 2023-1-20 17:00
MyModHeaven 发表于 2023-1-20 16:28
那第一个结果的数量不应该是第二个的一半吗?

第一条语句是在title去重之后的里面,挑选出和外面重复 ...

第一条是把所有titile相同的record都进行计数
第二题是如果title满足条件就技术 所以不存在倍数关系
cshadow 发表于 2023-1-20 17:06
第一条 SQL  难道没有语法错误吗
 楼主| MyModHeaven 发表于 2023-1-20 17:14
cshadow 发表于 2023-1-20 17:06
第一条 SQL  难道没有语法错误吗

没有的,可以正常查询
xiao_yang 发表于 2023-1-20 17:25
2楼正解,第一个分组去重了,第二个没有分组去重
scyslzwapj 发表于 2023-1-20 18:22
cshadow 发表于 2023-1-20 17:06
第一条 SQL  难道没有语法错误吗

标准sql92会报错,mysql扩展了的 不会报错
cshadow 发表于 2023-1-20 18:53
scyslzwapj 发表于 2023-1-20 18:22
标准sql92会报错,mysql扩展了的 不会报错

哦 这样啊  mysql 用的不多
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 01:51

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表