SQL Server笔记 -- 第73章:排序/对行进行排序

73.1 基础用法

首先创建示例表:

sql 复制代码
-- 创建示例表
CREATE TABLE SortOrder (
  ID   INT IDENTITY PRIMARY KEY,
  Text VARCHAR(256)
)
GO

-- 插入测试数据
INSERT INTO SortOrder ([Text])
SELECT ('Lorem ipsum dolor sit amet, consectetur adipiscing elit')
UNION ALL
SELECT ('Pellentesque eu dapibus libero')
UNION ALL
SELECT ('Vestibulum et consequat est, ut hendrerit ligula')
UNION ALL
SELECT ('Suspendisse sodales est congue lorem euismod, vel facilisis libero pulvinar')
UNION ALL
SELECT ('Suspendisse lacus est, aliquam at varius a, fermentum nec mi')
UNION ALL
SELECT ('Praesent tincidunt tortor est, nec consequat dolor malesuada quis')
UNION ALL
SELECT ('Quisque at tempus arcu')
GO

检索数据时,如果不指定排序子句(ORDER BY),SQL Server 在任何时刻都不保证结果顺序。

没有 ORDER BY == 没有排序,这一点毫无疑问。

sql 复制代码
-- 看似按主键排序,实则无法保证永远如此;留在生产环境必出意外
SELECT * FROM SortOrder
GO

排序方向:

  • 升序(ASC,默认)
  • 降序(DESC)
sql 复制代码
-- 升序
SELECT * FROM SortOrder ORDER BY ID ASC
GO

-- 升序可省略 ASC
SELECT * FROM SortOrder ORDER BY ID
GO

-- 降序
SELECT * FROM SortOrder ORDER BY ID DESC
GO

对文本列排序时,顺序受排序规则(collation)影响。

排序会消耗资源,合理建立索引可提高性能。

可用伪随机方式打乱顺序:

sql 复制代码
SELECT * FROM SortOrder ORDER BY CHECKSUM(NEWID())
GO

在存储过程末尾固定排序,供前端直接调用:

sql 复制代码
CREATE PROCEDURE GetSortOrder
AS
SELECT * FROM SortOrder ORDER BY ID DESC
GO
EXEC GetSortOrder
GO

视图中的排序(不推荐):

sql 复制代码
-- 可能失效,依赖部署与更新方式
CREATE VIEW VwSortOrder1
AS
SELECT TOP 100 PERCENT * FROM SortOrder ORDER BY ID DESC
GO
SELECT * FROM VwSortOrder1
GO

-- 可行但不应使用
CREATE VIEW VwSortOrder2
AS
SELECT TOP 99999999 * FROM SortOrder ORDER BY ID DESC
GO
SELECT * FROM VwSortOrder2
GO

ORDER BY 可使用列名、别名或列序号:

sql 复制代码
SELECT * FROM SortOrder ORDER BY [Text]

-- 使用别名
SELECT ID,
       [Text] + ' (' + CAST(ID AS nvarchar(10)) + ')' AS Msg
FROM SortOrder
ORDER BY Msg

-- 使用列号(易出错,不建议生产使用)
SELECT * FROM SortOrder ORDER BY 2

73.2 使用 CASE 自定义排序

若需按自定义层次而非字母/数值排序,可用 CASE 赋予序号:

示例数据:

复制代码
Group
-------
Total
Young
MiddleAge
Old
Male
Female

默认按字母排序:

sql 复制代码
SELECT * FROM MyTable ORDER BY [Group]
-- 结果:Female, Male, MiddleAge, Old, Total, Young

使用 CASE 指定顺序:

sql 复制代码
SELECT * FROM MyTable
ORDER BY CASE [Group]
  WHEN 'Total'     THEN 10
  WHEN 'Male'      THEN 20
  WHEN 'Female'    THEN 30
  WHEN 'Young'     THEN 40
  WHEN 'MiddleAge' THEN 50
  WHEN 'Old'       THEN 60
END

结果按指定层次排序:

复制代码
Total
Male
Female
Young
MiddleAge
Old
相关推荐
m0_613856292 小时前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
Adios7943 小时前
VPR:Pitts50K和Norland数据集下载
数据库
东风破1373 小时前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
叶小鸡3 小时前
Java 篇-项目实战-苍穹外卖-笔记汇总
java·开发语言·笔记
收获不止数据库3 小时前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
小宇的天下3 小时前
Virtuoso GUI 界面中的关键模块定义
数据库
bqq198610263 小时前
MySQL 5.7 与 MySQL 8.0 的主要区别
数据库·mysql
juniperhan3 小时前
Flink 系列第21篇:Flink SQL 函数与 UDF 全解读:类型推导、开发要点与 Module 扩展
java·大数据·数据仓库·分布式·sql·flink
Leinwin4 小时前
双城奔赴,智领未来:领驭科技亮相2026微软AI Tour上海·香港站
人工智能·科技·microsoft
Elastic 中国社区官方博客4 小时前
Elastic-caveman : 在不损失 Elastic 最佳效果的情况下,将 AI 响应 tokens 减少64%
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·全文检索