SetServer('127.0.0.1',10312);$sphinxapi->SetConnectTimeout(3);$sphinxapi->SetMatchMode(SPH_MATCH_BOOLEAN);$sphinxa" />

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

在項目中靈活運用合適的排序方法(Sphinx,SQL,Y

系統 2167 0

本文總結一下最近項目中用到的各種排序方法,如需轉載,請注明文章出處 微笑


1,Sphinx排序

?

?

    ? ? ? ? Yii::import('ext.SphinxClient');

        $sphinxapi = new SphinxClient();

        $sphinxapi->SetServer('127.0.0.1', 10312);

        $sphinxapi->SetConnectTimeout(3);

        $sphinxapi->SetMatchMode(SPH_MATCH_BOOLEAN);

        $sphinxapi->SetArrayResult(true);

        $sphinxapi->SetGroupBy('type', SPH_GROUPBY_ATTR,"@count desc");

        $sphinxapi->SetLimits(0, 9999, 10000);

        $result = $sphinxapi->Query('', 'main;delta');

        unset($sphinxapi);
  


其中

     SPH_GROUPBY_ATTR,"@count desc"
  

指定了按照 @count 降序排列

?


2,SQL排序(讓某一列根據指定的數組排序,而不是本表字段)

???? ?????

有時候我們需要從數據庫中找到的數據按照我們已有的數組順序進行排列,而不是簡單的根據數據表字段進行 order by

比如:

我們有一個數組 $IDArray=array(13,24,2,23,21,10,22,12,26,27,19,20,8,14,25,9,11,1,6);

現在需要從shop表中查找19個數據,并且讓shop的id根據$IDArray中的順序來排列

可以使用, find_in_set (id,'************')來實現


?

    SELECT id, name FROM shop WHERE id IN(13,24,2,23,21,10,22,12,26,27,19,20,8,14,25,9,11,1,6) order by find_in_set(id,'13,24,2,23,21,10,22,12,26,27,19,20,8,14,25,9,11,1,6')
  


當然,我們遇到的常常是動態的情況,這是可以用數組->字符串的法寶 join

?

?

    
      $sql = "SELECT id, name FROM shop WHERE id IN(".join(',', array_keys($IDARRAY)).") order by  find_in_set(id,'".join(',', array_keys($IDARRAY))."') ";



$rawDataAll = Yii::app()->db->createCommand($sql)->queryAll();
    
  


?

關于 find_in_set (id,'************') ,的用法擴展可以

參考: mysql中替代charindex的函數substring_index、find_in_set


3,Array數組根據自己的任意元素進行排序


把這個方法封裝成一個類,在Yii項目中隨意調用

?

    ArrayHelper::array_sort($bodyArray, 'count', 'desc')
  

?

?

    <?php

class ArrayHelper extends CController

{

    public function array_sort($arr, $keys, $type='asc')

    {

        $keysvalue = $new_array = array();

        foreach($arr AS $k=>$v)

        {

            $keysvalue[$k] = $v[$keys];

        }

        if($type == 'asc')

        {

            asort($keysvalue);

        }

        else

        {

            arsort($keysvalue);

        }

        reset($keysvalue);

        foreach ($keysvalue as $k=>$v)

        {

            $new_array[$k] = $arr[$k];

        }

        return $new_array;

    }

}

?>
  



在項目中靈活運用合適的排序方法(Sphinx,SQL,Yii,數組)


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 最新色图| 亚洲孕交 | 日日干干夜夜 | 国产大片91精品免费看3 | 天天看天天爽天天摸天天添 | av电影网站在线观看 | 久草在线视频中文 | 久久国产婷婷国产香蕉 | 国产精品综合色区在线观看 | 国产成人精品一区二区三区四区 | 久久福利剧场 | 欧美十区 | 亚洲另类天天更新影院在线观看 | 99视频有精品视频免费观看 | 成人禁在线观看网站 | 欧美大香线蕉线伊人久久 | 亚洲天天看| 浮力影院网站午夜 | 国产一级做a爰片在线 | 欧美性猛交一区二区三区精品 | 亚洲精品影院 | 91高清在线观看 | 日韩中文字幕在线视频 | 性开放的欧美大片按摩 | 亚洲天天综合色制服丝袜在线 | 一级做a免费视频 | 亚洲精品乱码久久久久久v 国产高清免费视频 | 色黄视频免费观看 | 欧美精品网站 | 丝袜捆绑调教视频免费区 | 久久中文字幕一区二区 | 国产欧美精品一区二区三区 | 日本精品a在线观看 | v片在线免费观看 | 国产精品久久婷婷六月丁香 | 精品免费久久久久欧美亚一区 | 国产精品夜色一区二区三区 | asian gaysex | 九九热色| 色狠狠色综合吹潮 | 999久久久 |