国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

如何利用php array_multisort函數 對數據庫結果進行復雜排序

2024-05-04 23:10:28
字體:
來源:轉載
供稿:網友

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

關聯(string)鍵名保持不變,但數字鍵名會被重新索引。

排序順序標志:
SORT_ASC – 按照上升順序排序
SORT_DESC – 按照下降順序排序

排序類型標志:
SORT_REGULAR – 將項目按照通常方法比較
SORT_NUMERIC – 將項目按照數值比較
SORT_STRING – 將項目按照字符串比較

每個數組之后不能指定兩個同類的排序標志。每個數組后指定的排序標志僅對該數組有效 – 在此之前為默認值 SORT_ASC 和 SORT_REGULAR。

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

本函數的參數結構有些不同尋常,但是非常靈活。第一個參數必須是一個數組。接下來的每個參數可以是數組或者是下面列出的排序標志。

這樣我們現在有這樣一組數據

復制代碼 代碼如下:


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


這樣就實現了我們需要的功能

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 门源| 合山市| 呼图壁县| 汝城县| 亚东县| 沙河市| 忻城县| 仁怀市| 海城市| 德庆县| 陆川县| 兖州市| 白朗县| 松滋市| 衡山县| 东至县| 沙湾县| 瑞丽市| 昭通市| 余姚市| 丰都县| 徐水县| 洛隆县| 靖宇县| 扶绥县| 昆明市| 唐海县| 扎鲁特旗| 巫山县| 扶沟县| 内黄县| 达州市| 西畴县| 咸丰县| 舟山市| 沾化县| 商城县| 正定县| 通榆县| 庄河市| 平泉县|