如何利用php array_multisort函數(shù) 對(duì)數(shù)據(jù)庫(kù)結(jié)果進(jìn)行復(fù)雜排序
首先講一下需求:數(shù)據(jù)庫(kù)中有4個(gè)字段分別是id,volume,edition,name. 要求對(duì)查詢結(jié)果按照volume+edition從大到小排序。
下面將一下array_multisort函數(shù)
array_multisort() 可以用來(lái)一次對(duì)多個(gè)數(shù)組進(jìn)行排序,或者根據(jù)某一維或多維對(duì)多維數(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)志僅對(duì)該數(shù)組有效 – 在此之前為默認(rèn)值 SORT_ASC 和 SORT_REGULAR。
輸入數(shù)組被當(dāng)成一個(gè)表的列并以行來(lái)排序——這類似于 SQL 的 ORDER BY 子句的功能。第一個(gè)數(shù)組是要排序的主要數(shù)組。數(shù)組中的行(值)比較為相同的話就按照下一個(gè)輸入數(shù)組中相應(yīng)值的大小來(lái)排序,依此類推。
本函數(shù)的參數(shù)結(jié)構(gòu)有些不同尋常,但是非常靈活。第一個(gè)參數(shù)必須是一個(gè)數(shù)組。接下來(lái)的每個(gè)參數(shù)可以是數(shù)組或者是下面列出的排序標(biāo)志。
這樣我們現(xiàn)在有這樣一組數(shù)據(jù)
// 這是一組從數(shù)據(jù)庫(kù)查詢出來(lái)的結(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ù)組來(lái)
foreach($data as $val){
$arr[] = $val['volume'] + $val['edition'];
}
// 將$arr根據(jù)降序排列
// 把 $data 作為最后一個(gè)參數(shù),以通用鍵排序
array_multisort($arr, SORT_DESC, $data);
這樣就實(shí)現(xiàn)了我們需要的功能
- PHP數(shù)組函數(shù)array_multisort()用法實(shí)例分析
- php中array_multisort對(duì)多維數(shù)組排序的方法
- PHP使用array_multisort對(duì)多個(gè)數(shù)組或多維數(shù)組進(jìn)行排序
- php二維數(shù)組排序方法(array_multisort usort)
- PHP array_multisort() 函數(shù)的深入解析
- php的array_multisort()使用方法介紹
- PHP array_multisort()函數(shù)的使用札記
- php 數(shù)組排序 array_multisort與uasort的區(qū)別
- array_multisort實(shí)現(xiàn)PHP多維數(shù)組排序示例講解
- php關(guān)于array_multisort多維數(shù)組排序的使用說(shuō)明
- php array_map array_multisort 高效處理多維數(shù)組排序
- php array_multisort 對(duì)數(shù)組進(jìn)行排序詳解及實(shí)例代碼
相關(guān)文章
PDO版本問(wèn)題 Invalid parameter number: no parameters were bound
發(fā)現(xiàn)在客戶的某個(gè)PHP版本下,執(zhí)行某類操作的時(shí)候,總是會(huì)報(bào)如下錯(cuò)誤 Invalid parameter number: no parameters were bound,經(jīng)google,發(fā)現(xiàn)是php版本過(guò)低導(dǎo)致2013-01-01
PHP實(shí)現(xiàn)預(yù)定義鉤子和自定義鉤子的簡(jiǎn)單示例
這篇文章主要給大家介紹了PHP實(shí)現(xiàn)預(yù)定義鉤子和自定義鉤子,在PHP中,鉤子(Hooks)是一種機(jī)制,允許開(kāi)發(fā)人員在特定的時(shí)機(jī)插入自定義代碼,通過(guò)使用鉤子,開(kāi)發(fā)人員可以在應(yīng)用程序的特定事件發(fā)生時(shí)執(zhí)行自定義的功能或邏輯,文中有詳細(xì)的代碼講解,需要的朋友可以參考下2023-11-11
PHP中include與require使用方法區(qū)別詳解
這篇文章詳細(xì)介紹了PHP中include與require使用方法的區(qū)別,有需要的朋友可以參考一下2013-10-10
PHP代碼加密和擴(kuò)展解密實(shí)戰(zhàn)
這篇文章主要介紹了PHP代碼加密和擴(kuò)展解密實(shí)戰(zhàn),對(duì)加密解密感興趣的同學(xué),可以參考下2021-04-04

