where id in用 order by field 保持排序

先看下mysql的默认排序

select id from article where id in(63261,63262,63269);

 

+-------+
|   id     |
+-------+
| 63261 |
| 63262 |
| 63269 |
+-------+
 
如果我想63262在第一个63261在最后一个怎么办?
select id from article where id in(63261,63262,63269) order by field(id,63262,63269,63261);
+-------+
|   id     |
+-------+
| 63262 |
| 63269 |
| 63261 |
+-------+

转载于:https://www.cnblogs.com/yjtm/p/7459284.html

ORDER BY FIELD() 是一种对查询结果排序的方法,它可以根据指定的字段值顺序进行排序。在 ORDER BY 子句中使用 FIELD() 函数可以指定一个表达式和一个可选的值列表,然后按照值列表中的顺序进行排序。例如,可以使用 FIELD() 函数对用户表中的姓名字段进行排序,如下所示: SELECT name FROM users ORDER BY FIELD(name, 'John', 'Mary', 'Peter') \[1\] 同样地,可以在查询产品表时使用 FIELD() 函数对产品名称进行排序,如下所示: SELECT product_id, product_name, price FROM products ORDER BY FIELD(product_name, 'Banana', 'Apple', 'Orange', 'Mango') DESC \[2\] 此外,还可以使用 FIELD() 函数对指定的字段值进行排序,如下所示: SELECT * FROM t_student WHERE id IN(2, 4, 1, 5, 3, 6) ORDER BY FIELD(id, 2, 4, 1, 5, 3, 6) \[3\] 通过使用 ORDER BY FIELD() 方法,可以根据指定的字段值顺序对查询结果进行排序。 #### 引用[.reference_title] - *1* *3* [order by field()使用场景](https://blog.csdn.net/incredible1024/article/details/130178053)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [order by FIELD 及其平替函数 的用法](https://blog.csdn.net/weixin_65846839/article/details/130725864)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值