随笔 - 268  文章 - 0  评论 - 1028  阅读 - 160万

也做SQL查询:班级总成绩 前三名,总成绩有相等的情况

刚刚看到一篇博客,原帖链接:http://www.cnblogs.com/HCCZX/archive/2012/11/07/2758036.html

 

通常想到子查询或者临时表外加聚合函数都是没错的,但是真写起来发现SQL语句比较不那么人道,阅读体验不好。追求优雅的Coder通常一看到是SQL Server 2005+,条件反射地想到窗口函数和公用表表达式CTE。一种SQL查询实现如下:

1
2
3
4
5
6
7
8
9
10
11
WITH ScoreInfo AS (
SELECT [Student_No], [Student_Name],[Chinese],[Math],[English],[totalScore]
      ,DENSE_RANK() OVER(ORDER BY totalScore DESC) AS '名次'
  FROM [Record] )
   
SELECT CASE 名次  WHEN 1 THEN '第一名'
                  WHEN 2 THEN '第二名'
                  WHEN 3 THEN '第三名'
                  END AS '排名',
[Student_No], [Student_Name],[Chinese],[Math],[English],[totalScore]
FROM ScoreInfo WHERE  名次<4 --取前三名

这样的SQL可读性是不是立刻变得简洁鲜明一目了然?

posted on   JeffWong  阅读(3219)  评论(1编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
历史上的今天:
2009-11-07 整理发布html的select控件实用js操作
< 2012年11月 >
28 29 30 31 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 1
2 3 4 5 6 7 8

I know how to make it works and I want to know how it works.
点击右上角即可分享
微信分享提示