MySQL需要根據(jù)特定順序排序的實現(xiàn)方法
0 寫在前面
在進行業(yè)務需求的時候,不會根據(jù)排序去選擇數(shù)據(jù)。例如,在導出的時候數(shù)據(jù)排序是根據(jù)編輯時間去排序的,那么他的主鍵id會打亂。
假如: 要導出id為 3 ,1 , 2 ,6 , 5 的數(shù)據(jù)并且根據(jù)此順序?qū)С觥?/p>
1 問題引入
如果直接在MySQL中寫
SELECT 數(shù)據(jù) FROM 表名 WHERE 表名id IN (3, 1, 2, 6, 5)
會發(fā)生MYSQL默認排序規(guī)則;
2 問題解決
使用mysql的FIELD()
函數(shù)進行自定義排序
使用id為例:
SELECT 數(shù)據(jù) FROM 表名 WHERE 表名.id IN (所有id) order by FIELD(id, 排序規(guī)則);
注意:排序規(guī)則需要一一對應,即使在 in()
的數(shù)據(jù)不影響,只要在field()確認規(guī)則即可
3 寫在末尾
因為從業(yè)務里傳過來的數(shù)據(jù)肯定是規(guī)則排序,所以建議用IN() 和 FIELD()里的排序 對應起來是最保險的。
到此這篇關(guān)于MySQL需要根據(jù)特定順序排序的實現(xiàn)方法的文章就介紹到這了,更多相關(guān)MySQL 特定順序排序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Django創(chuàng)建項目+連通mysql的操作方法
這篇文章主要介紹了Django創(chuàng)建項目+連通mysql的操作方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03MYSQL 創(chuàng)建函數(shù)出錯的解決方案
在程序開發(fā)過程中,大家有沒有遇到過mysql函數(shù)不能創(chuàng)建,我是遇到過,是一個很麻煩的問題,上網(wǎng)搜了些相關(guān)資料,整理在一起了,供大家參考,幫助那些需要幫助的朋友2015-08-08