Mysql 使用case排序

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: Mysql自定义排序使用case进行排序

在 MySQL 中,你可以使用 ORDER BY 子句来对结果进行排序。默认情况下,ORDER BY 子句按照升序对字段进行排序。如果你想按照降序排序,你可以使用 DESC 关键字。

除了默认的升序和降序排序,你还可以使用自定义排序顺序。这可以通过使用 CASE 语句来实现。

下面是一个示例,展示如何在 MySQL 中使用自定义排序顺序:

假设你有一个名为 students 的表,其中包含学生的姓名和成绩。你想按照成绩排序,但是你希望首先展示成绩优秀的学生(假设成绩大于等于 80),然后展示表现良好的学生(成绩在 60 到 80 之间),最后展示表现较差的学生(成绩小于 60)。

你可以使用以下查询来实现这个排序:

SELECT name, score
FROM students
ORDER BY 
    CASE
        WHEN score >= 80 THEN 1
        WHEN score >= 60 THEN 2
        ELSE 3
    END,
    score;

在这个查询中,我们首先使用 CASE 语句为每个成绩段分配一个数字值。然后,我们使用 ORDER BY 子句按照这个数字值进行排序,然后按照成绩进行排序。

这将首先按照成绩段进行排序,然后按照成绩在每个成绩段内进行排序。因此,优秀的学生将首先展示,然后是表现良好的学生,最后是表现较差的学生。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
安全 关系型数据库 MySQL
总结MySQL 的一些知识点:MySQL 排序(上)
总结MySQL 的一些知识点:MySQL 排序
|
5月前
|
SQL 前端开发 关系型数据库
MYSQL 排序和分组怎么做?
MYSQL 排序和分组怎么做?
41 1
|
6天前
|
关系型数据库 MySQL
Mysql语句_查询数据百分比、人员年龄、数据排序、添加查询时的列属性、合并查询结果
Mysql语句_查询数据百分比、人员年龄、数据排序、添加查询时的列属性、合并查询结果
10 0
|
28天前
|
缓存 关系型数据库 MySQL
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
|
2月前
|
存储 人工智能 关系型数据库
详细介绍TiDB 与 MySQL 中的常用字符集及排序规则
一文理清 TiDB 与 MySQL 中的常用字符集及排序规则
143 6
|
2天前
|
SQL 关系型数据库 MySQL
【MySQL】:分组查询、排序查询、分页查询、以及执行顺序
【MySQL】:分组查询、排序查询、分页查询、以及执行顺序
13 0
|
14天前
|
SQL 关系型数据库 MySQL
排序与分页——“MySQL数据库”
排序与分页——“MySQL数据库”
|
23天前
|
SQL 关系型数据库 MySQL
mysql基本查询、运算符、排序和分页
mysql基本查询、运算符、排序和分页
|
2月前
|
关系型数据库 MySQL 开发工具
MySQL分组后,组内排序,然后取每组的第一条数据
MySQL分组后,组内排序,然后取每组的第一条数据
18 1
|
2月前
|
关系型数据库 MySQL
Mysql基础第八天,排序检索数据
Mysql基础第八天,排序检索数据
25 1