如何利用php array_multisort函數 對資料庫排序

來源:互聯網
上載者:User

標籤:比較   不同   第一個   order by   接下來   asc   數字鍵名   str   排序   

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

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

排序次序標誌:
SORT_ASC C 按照上升順序排序
SORT_DESC C 按照下降順序排序
排序類型標誌:
SORT_REGULAR C 將項目按照通常方法比較
SORT_NUMERIC C 將項目按照數值比較
SORT_STRING C 將項目按照字串比較
每個數組之後不能指定兩個同類的排序標誌。每個數組後指定的排序標誌僅對該數組有效 C 在此之前為預設值 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);

如何利用php array_multisort函數 對資料庫排序

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.