如何利用php array_multisort函數(shù) 對數(shù)據(jù)庫結果進行復雜排序
首先講一下需求:數(shù)據(jù)庫中有4個字段分別是id,volume,edition,name. 要求對查詢結果按照volume+edition從大到小排序。
下面將一下array_multisort函數(shù)
array_multisort() 可以用來一次對多個數(shù)組進行排序,或者根據(jù)某一維或多維對多維數(shù)組進行排序。
關聯(lián)(string)鍵名保持不變,但數(shù)字鍵名會被重新索引。
排序順序標志:
SORT_ASC – 按照上升順序排序
SORT_DESC – 按照下降順序排序
排序類型標志:
SORT_REGULAR – 將項目按照通常方法比較
SORT_NUMERIC – 將項目按照數(shù)值比較
SORT_STRING – 將項目按照字符串比較
每個數(shù)組之后不能指定兩個同類的排序標志。每個數(shù)組后指定的排序標志僅對該數(shù)組有效 – 在此之前為默認值 SORT_ASC 和 SORT_REGULAR。
輸入數(shù)組被當成一個表的列并以行來排序——這類似于 SQL 的 ORDER BY 子句的功能。第一個數(shù)組是要排序的主要數(shù)組。數(shù)組中的行(值)比較為相同的話就按照下一個輸入數(shù)組中相應值的大小來排序,依此類推。
本函數(shù)的參數(shù)結構有些不同尋常,但是非常靈活。第一個參數(shù)必須是一個數(shù)組。接下來的每個參數(shù)可以是數(shù)組或者是下面列出的排序標志。
這樣我們現(xiàn)在有這樣一組數(shù)據(jù)
// 這是一組從數(shù)據(jù)庫查詢出來的結果
$data[] = array('volume' => 67, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 1);
$data[] = array('volume' => 85, 'edition' => 6);
$data[] = array('volume' => 98, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 6);
$data[] = array('volume' => 67, 'edition' => 7);
//我們需要先做出一個volume+edition的數(shù)組來
foreach($data as $val){
$arr[] = $val['volume'] + $val['edition'];
}
// 將$arr根據(jù)降序排列
// 把 $data 作為最后一個參數(shù),以通用鍵排序
array_multisort($arr, SORT_DESC, $data);
這樣就實現(xiàn)了我們需要的功能
- PHP數(shù)組函數(shù)array_multisort()用法實例分析
- php中array_multisort對多維數(shù)組排序的方法
- PHP使用array_multisort對多個數(shù)組或多維數(shù)組進行排序
- php二維數(shù)組排序方法(array_multisort usort)
- PHP array_multisort() 函數(shù)的深入解析
- php的array_multisort()使用方法介紹
- PHP array_multisort()函數(shù)的使用札記
- php 數(shù)組排序 array_multisort與uasort的區(qū)別
- array_multisort實現(xiàn)PHP多維數(shù)組排序示例講解
- php關于array_multisort多維數(shù)組排序的使用說明
- php array_map array_multisort 高效處理多維數(shù)組排序
- php array_multisort 對數(shù)組進行排序詳解及實例代碼
相關文章
php中json_encode UTF-8中文亂碼的更好解決方法
網(wǎng)上找到說json_encode編碼設置為UTF-8中文就不會亂碼,在用過一段時間之后就不太管用了,下面與大家分享更好的方法2014-09-09WordPress開發(fā)中用于標題顯示的相關函數(shù)使用解析
這篇文章主要介紹了WordPress開發(fā)中用于標題顯示的相關函數(shù)使用解析,講解了single_cat_title函數(shù)和get_the_title函數(shù)和the_title函數(shù)的用法,需要的朋友可以參考下2016-01-01PHP實現(xiàn)UTF-8文件BOM自動檢測與移除實例
這篇文章主要介紹了PHP實現(xiàn)UTF-8文件BOM自動檢測與移除的方法,實例講述了UTF-8文件BOM信息的原理與PHP對此的檢測與刪除方法,是非常實用的技巧,需要的朋友可以參考下2014-11-11