mysql 查询结果集按照指定的字段值顺序排序

mysql 查询结果如果不给予指定的order by ,那么mysql会按照主键顺序(innodb引擎)对结果集加以排序,那么最后的排序可能就不是你想要的排序结果。

举个例子,我要按照前端传过来的mongoId集合来查询数据库并且返回同样排序的结果集合,如(M3,M5,M4),他们对应的主键顺序为(M4,M3,M5)。如果在查询语句中不加order by 对查询结果排序,那么结果就会变成主键顺序(M4,M3,M5)。

mysql 查询结果集按照指定的字段值顺序排序_第1张图片

就像上图,最后的结果是按VId排的序。那么如果想要按照(M3,M5,M4)的排序返回结果,就需要用到自排序字段  order by field ( value ,str1,str2,str3) 。

sql如下:

mysql 查询结果集按照指定的字段值顺序排序_第2张图片

 

转载于:https://www.cnblogs.com/shm-1255/p/8981217.html

你可能感兴趣的:(数据库,前端,java,ViewUI)