使用IN() 方法的MySQL 排序結果
使用包含有序ID 號碼的PHP 陣列時,可能需要擷取來自MySQL 資料庫的對應記錄,同時保留指定的順序。這可以使用 MySQL IN() 方法來實作。但是,IN() 方法通常不會維護結果中 ID 的順序。
解決方案:利用 FIELD() 函數
解決此問題,可以使用 MySQL FIELD() 函數。雖然傳統上與字串操作相關,FIELD() 函數也可以有效地與數字一起使用:
ORDER BY FIELD(field_name, 3,2,5,7,8,1)
在此範例中,ORDER BY 子句使用FIELD() 函數根據括號內指定的順序,確保傳回的記錄與PHP 數組中的ID 序列相符。
例如,如果field_name 依下列順序包含ID 號碼: 9, 4, 5, 8, 3,結果將如下排序:
4 - Article 4 9 - Article 9 5 - Article 5 8 - Article 8 3 - Article 3
透過將FIELD() 函數合併到ORDER BY 子句中,開發人員可以使用MySQL IN 有效檢索有序結果() 方法,即使使用數字ID 值也是如此。
以上是如何使用 IN() 方法對 MySQL 結果進行排序並維護順序?的詳細內容。更多資訊請關注PHP中文網其他相關文章!