首页 >数据库 >mysql教程 >如何在 SQL 中对具有特定值的行进行优先级排序然后按字母顺序排序?

如何在 SQL 中对具有特定值的行进行优先级排序然后按字母顺序排序?

Barbara Streisand
Barbara Streisand原创
2025-01-01 03:07:09568浏览

How to Prioritize Rows with a Specific Value Then Sort Alphabetically in SQL?

首先返回具有特定值的行

问题:

您希望检索数据从表中,优先考虑特定列中包含特定值的行。其余行应基于另一列按字母顺序排列。

考虑具有以下结构的示例表 Users:

id name city
1 George Seattle
2 Sam Miami
3 John New York
4 Amy New York
5 Eric Chicago
6 Nick New York

解决方案:

要根据特定值确定行的优先级并按字母顺序排列剩余行,请使用以下命令查询:

ORDER BY CASE WHEN city = 'New York' THEN 1 ELSE 2 END, city

解释:

CASE 表达式将优先级值 1 分配给城市列与指定值(“纽约”)匹配的行所有其他行的优先级值为 2。这可确保包含“New York”的行首先出现在结果集中。

ORDER BY 子句的第二部分,城市,根据城市列进一步按字母顺序对每个优先级组中的行进行排序。

此查询将返回以下结果:

id name city
3 John New York
4 Amy New York
6 Nick New York
1 George Seattle
2 Sam Miami
5 Eric Chicago

以上是如何在 SQL 中对具有特定值的行进行优先级排序然后按字母顺序排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn