MySQL 之ORDER BY FIELD

在使用MySQL的排序時,可能需要根據某個字段取值的特定順序來進行排序。此時,我們就可以使用ORDER BY FIELD。

以fruit表為例,fruit表的“name”字段用于保存各個fruit的名字:Apple, Banana, Orange, Pear.
現在,我們要對fruit中查詢的結果進行排序,希望結果按照:Banana, Orange, Pear, Orange 的順序排列。就可以使用 ORDER BY FIELD來操作。
SELECT * FROM fruit
ORDER BY FIELD(name, 'Banana', 'Apple', 'Pear', 'Orange'), variety;
查詢結果如下:
+----------+--------+---------------------+
| fruit_id | name | variety |
+----------+--------+---------------------+
| 11 | Banana | Burro |
| 12 | Banana | Cavendish |
| 10 | Banana | Plantain |
| 6 | Apple | Cox's Orange Pippin |
| 7 | Apple | Granny Smith |
| 1 | Apple | Red Delicious |
| 8 | Pear | Anjou |
| 4 | Pear | Bartlett |
| 2 | Pear | Comice |
| 5 | Orange | Blood |
| 3 | Orange | Navel |
| 9 | Orange | Valencia |
+----------+--------+---------------------+
參考:http://www.electrictoolbox.com/mysql-order-specific-field-values/

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容