首先返回具有特定值的行
问题:
您希望检索数据从表中,优先考虑特定列中包含特定值的行。其余行应基于另一列按字母顺序排列。
考虑具有以下结构的示例表 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中文网其他相关文章!