首页 » 数据库 » 如何让mysql in()查询结果按in集合顺序显示的方法

如何让mysql in()查询结果按in集合顺序显示的方法

高蒙 2016/09/23 09:46 5.2k浏览 0评论 Mysql


我们在用mysql查询in操作的时候,你会发现返回的数据,并不是我们想要的排序。如果情况是这样的话,那么在取回来之后还要通过foreach重新的在排序。这样即显得笨拙,也造成不必要的数据运行。这时,我们就在想如果在查询的时候,返回来的结果集就是我们想要的排序方式,那不是更好吗?其实,mysql已经为我们准备好了,只是我们平时用的少,不知道此方法而已。那么,下面就看看,mysql中的in操作,返回结果集按顺序输出。

sql语句:

SELECT * FROM
yii_user WHERE id IN (20, 16, 21, 15, 17, 22, 18, 23)

111.png

处理的sql语句:

SELECT * FROM
yii_user WHERE id IN (20, 16, 21, 15, 17, 22, 18, 23) ORDER BY
field(id, 20, 16, 21, 15, 17, 22, 18, 23);

222.png

按照上面处理过的sql语句查询的话,那么返回的结果集就是我们自己定义的排序方式输出,id会按20, 16, 21, 15, 17, 22, 18, 23排序的输出。





相关文章

我有话说

站长昵称:(*)

输入内容:

选个头像:

评论列表

    ...

    高蒙

    男, PHP程序猿

    文章

    481

    标签

    38

    热度

    10w+

    南京, 江苏, 中国

    人生要是没有理想, 那跟咸鱼有什么分别。