MySQL 的 order by 简化(使用列序号和列别名排序)

order by 使用列序号排序

在如下例子中的复杂 SQL,select 出来的部分列包含复杂的函数处理,当我希望按品牌、地区和车型排序,order by 部分就要把所有语句都写上,显得很冗余。

sql 复制代码
select distinct 
    'hyundaiKia_online' as analyser,
    vehicle_model as vehicle_model,
    features,
    brand as '品牌',
    area as '地区',
    CONCAT(vehicle_model, '-', TRIM(REPLACE(catalogName, '#', ''))) as '车型'
from raw_vehicle_data
where vehicle_model != ''
ORDER BY brand, area, CONCAT(vehicle_model, '-', TRIM(REPLACE(catalogName, '#', '')))

order by 语句可以使用 select 的列序号替代 select 的列完成排序工作(序号从 1 开始递增)

SQL 可以很好地被简化,通过序号直接指定按 select 出来的那一列进行排序。

sql 复制代码
select distinct 
    'hyundaiKia_online' as analyser,
    vehicle_model as vehicle_model,
    features,
    brand as '品牌',
    area as '地区',
    CONCAT(vehicle_model, '-', TRIM(REPLACE(catalogName, '#', ''))) as '车型'
from raw_vehicle_data
where vehicle_model != ''
ORDER BY 4, 5, 6

甚至还可以加上 desc 和 asc 指定某个列的升序、降序排序,默认是 asc 升序。

sql 复制代码
...
ORDER BY 4 desc, 5 asc, 6

order by 使用列别名排序

使用select 定义的列别名也可以实现简化 order by 语句

sql 复制代码
select distinct 
    'hyundaiKia_online' as analyser,
    vehicle_model as vehicle_model,
    features,
    brand as '品牌',
    area as '地区',
    CONCAT(vehicle_model, '-', TRIM(REPLACE(catalogName, '#', ''))) as '车型'
from raw_vehicle_data
where vehicle_model != ''
ORDER BY `品牌`, `地区`, `车型`

指定别名列时要用 ```````` 来括起来,否则是不生效的。

列别名、列序号还有字段名在 order by 语句上是可以混搭的,效果是完全一样的。

sql 复制代码
...
ORDER BY brand , `地区`, 6

两种方式的优缺点:

列序号这种方式虽然方便,但是存在维护成本高的问题,因为一旦 select 的字段顺序改变,order by 就一定要跟随变更,否则就按非期望字段排序导致排序失效。同时这种方式存在一定学习成本,不太熟悉该 SQL 背后业务的人,初次接触会觉得 SQL 可读性很差,纯数字难以理解,工程上建议辩证的使用。

而列别名方式比列序号更加灵活一些,select 字段变更顺序不需要调整 order by,且别名不变更的话一般都不需要对 order by 进行调整,且别名的方式其所能表达的含义比列序号的纯数字要强,SQL 可读性更高。

相关推荐
阿丰资源44 分钟前
SpringBoot+MySQL+MyBatis-Plus+Vue前后端分离仓库管理系统 (附资料)
spring boot·mysql·mybatis
小信丶1 小时前
Spring Cloud Stream EnableBinding注解详解:定义、应用场景与示例代码
java·spring boot·后端·spring
ffqws_1 小时前
Spring Boot入门:通过简单的注册功能串联Controller,Service,Mapper。(含有数据库建立,连接,及一些关键注解的讲解)
数据库·spring boot·后端
程序边界1 小时前
行标识符机制的技术演进与实践(下)——ROWID与实战应用
后端
Justin3go1 小时前
丢掉沉重的记忆:Codex、Claude Code 与 OpenCode 的上下文压缩术
前端·后端·架构
阿华田5121 小时前
MySQL性能优化大全
数据库·mysql·性能优化
不懂的浪漫2 小时前
mqtt-plus 架构解析(五):错误处理与 ErrorAction 聚合策略
java·spring boot·后端·物联网·mqtt·架构
被摘下的星星2 小时前
MySQL 别名使用规则详解
数据库·mysql
墨着染霜华2 小时前
MySQL 重复数据删除语句
数据库·mysql
卷福同学2 小时前
去掉手机APP开屏广告,李跳跳2.2下载使用
java·后端·算法