解决Sql中DIstinct与Order By共同使用的冲突问题


1.需求场景:

  需要把最新更新文章的前五名作者展示出来。

2.解决问题第一步:

  

select top 5 creator from table order by updateDate desc

 

结果:显示五条记录,但是名字是重复的。

3.解决问题第二步:

加Distinct

 

select distinct top 5 creator from table order by updateDate desc

结果:报错。如果指定了 SELECT DISTINCT,那么 ORDER BY 子句中的项就必须出现在选择列表中。

4.解决问题第四步:

按照错误提示修改代码

select  distinct top 5 creator,updatedate from table order by updatedate desc

 结果还是会出现重复的,日了狗了,去百度吧

5.正确答案:

select top 5  creator from brands  group by creator  order by max(updateDate) desc

 总结:对max()函数有了新的感觉了。并不只是放在select里简单获取一下最大值了,他其实也可以像asp.net webform Gridview下的rowdatabind()的那个感觉一样,随着结果集变动。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM