Mysql根据in的查询顺序进行排序

本文介绍如何使用MySQL的field()函数实现自定义排序功能,适用于不按常规顺序排列的数据集,如特定ID顺序。通过示例展示如何根据指定顺序对查询结果进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       有时候接到统计需求里发现统计需要的数据可能不是按一个通常的顺序排列,比如从小到大或者从大到小

像这种 20,16,35,100,201,131

那如果提数据导出需求的人要求按他要求顺序提供数据的话

可以使用mysql的field()函数进行自定义排序

例如:

SELECT
	*
FROM
	tb_merchant AS t
WHERE
	t.id IN (20,16,35,100,201,131) order by FIELD(id, 20,16,35,100,201,131);

Select * from [表名] where [查询字段] in ([查询条件]) order by field([需要排序的字段],...[','隔开,查询条件]...

效果如下....效率其实蛮高的,虽然官方推荐在程序里面进行排序

但是偶尔查个数据的话,还是用这个最快捷方便

是不是蛮方便的?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值