Hobart-Ljw 2016-02-20 08:14 采纳率: 25%
浏览 1421
已结题

关于mysql中查询重复数据的疑问

我有一个表叫做sc.
图片说明
现在要查询score中有相同分数的信息,
查询的sql语句是
select * from sc where score in (select score from sc group by score having count(score)>1);

我很好奇的是group by的执行顺序是比 having先执行啊,
按道理,执行了之后重复的score值是没有的,怎么还能再用having 来查出count(score)>1
的重复的score记录啊...好奇怪..谁能解答下。。谢谢

  • 写回答

3条回答

  • 仰望星空_Star 2016-02-20 10:10
    关注

    我的理解:group by 先按score分组(90,90) (100,100)... 之后having对每一组进行判断是否满足count(score)>1 满足则保留这一组,否则舍弃,之后再取出满足条件的score

    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 10月22日

悬赏问题

  • ¥15 用matlab 设计一个不动点迭代法求解非线性方程组的代码
  • ¥15 牛顿斯科特系数表表示
  • ¥15 arduino 步进电机
  • ¥20 程序进入HardFault_Handler
  • ¥15 oracle集群安装出bug
  • ¥15 关于#python#的问题:自动化测试
  • ¥20 问题请教!vue项目关于Nginx配置nonce安全策略的问题
  • ¥15 教务系统账号被盗号如何追溯设备
  • ¥20 delta降尺度方法,未来数据怎么降尺度
  • ¥15 c# 使用NPOI快速将datatable数据导入excel中指定sheet,要求快速高效