老坛酸菜吃鸭子 2022-03-27 00:00 采纳率: 83.3%
浏览 32
已结题

SQL top3 语句查询前三个数据,出来的数据却是倒数三个数据

问题遇到的现象和发生背景

SQL server

问题相关代码,请勿粘贴截图

```sql
select DISTINCT top 3  选修人数
from sequene


###### 运行结果及报错内容 

![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/655162013846142.png "#left")

![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/057123013846125.png "#left")


###### 我的解答思路和尝试过的方法 
我尝试建立倒序sequene表,但出来的结果不变
搞不明白到底是top语句出了问题,还是表出了问题
  • 写回答

4条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-03-27 14:25
    关注

    "top 3" 指的是排序取前3,并不是最大的3个值。
    你这个sql中并没有定义排序规则,排序是必须要使用order by 的

    select DISTINCT top 3  选修人数
    from sequene
    order by 选修人数 desc
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 3月30日
  • 已采纳回答 3月28日
  • 创建了问题 3月27日