溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么在php中利用array_multisort函數(shù)進(jìn)行復(fù)雜排序

發(fā)布時(shí)間:2020-12-28 15:38:28 來源:億速云 閱讀:156 作者:Leah 欄目:開發(fā)技術(shù)

本篇文章給大家分享的是有關(guān)怎么在php中利用array_multisort函數(shù)進(jìn)行復(fù)雜排序,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

首先講一下需求:數(shù)據(jù)庫中有4個(gè)字段分別是id,volume,edition,name. 要求對查詢結(jié)果按照volume+edition從大到小排序。
下面將一下array_multisort函數(shù)
array_multisort() 可以用來一次對多個(gè)數(shù)組進(jìn)行排序,或者根據(jù)某一維或多維對多維數(shù)組進(jìn)行排序。

關(guān)聯(lián)(string)鍵名保持不變,但數(shù)字鍵名會(huì)被重新索引。

排序順序標(biāo)志:
SORT_ASC – 按照上升順序排序
SORT_DESC – 按照下降順序排序

排序類型標(biāo)志:
SORT_REGULAR – 將項(xiàng)目按照通常方法比較
SORT_NUMERIC – 將項(xiàng)目按照數(shù)值比較
SORT_STRING – 將項(xiàng)目按照字符串比較

每個(gè)數(shù)組之后不能指定兩個(gè)同類的排序標(biāo)志。每個(gè)數(shù)組后指定的排序標(biāo)志僅對該數(shù)組有效 – 在此之前為默認(rèn)值 SORT_ASC 和 SORT_REGULAR。

輸入數(shù)組被當(dāng)成一個(gè)表的列并以行來排序——這類似于 SQL 的 ORDER BY 子句的功能。第一個(gè)數(shù)組是要排序的主要數(shù)組。數(shù)組中的行(值)比較為相同的話就按照下一個(gè)輸入數(shù)組中相應(yīng)值的大小來排序,依此類推。

本函數(shù)的參數(shù)結(jié)構(gòu)有些不同尋常,但是非常靈活。第一個(gè)參數(shù)必須是一個(gè)數(shù)組。接下來的每個(gè)參數(shù)可以是數(shù)組或者是下面列出的排序標(biāo)志。

這樣我們現(xiàn)在有這樣一組數(shù)據(jù)

復(fù)制代碼 代碼如下:


// 這是一組從數(shù)據(jù)庫查詢出來的結(jié)果
$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);
//我們需要先做出一個(gè)volume+edition的數(shù)組來
foreach($data as $val){
     $arr[] = $val['volume'] + $val['edition']; 
}
// 將$arr根據(jù)降序排列
// 把 $data 作為最后一個(gè)參數(shù),以通用鍵排序
array_multisort($arr, SORT_DESC, $data);

以上就是怎么在php中利用array_multisort函數(shù)進(jìn)行復(fù)雜排序,小編相信有部分知識點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI