thinkphp開發總結(五)——mongodb的一些操作

來源:互聯網
上載者:User

一、應用情境:尋找mongodb中新聞名不為“”,也不為null的新聞名稱,並根據熱度排名:

$map['title'] = array('$not'=>array('$in'=>array("", null)));$news=$this->where($map)->order('value desc')->field("title,class")->select();         

如果要獲得分類排名:

$res=array();foreach ($news as $k){      array_push($res,$k['title']);}$rank=array_search($this_news['title'],$res)+1;

如果不用order排名,對select下來的結果如何進行排名呢。

array_multisort(array_column($news,'value'),SORT_DESC,$news);

二、mongodb 模糊查詢

public function search_result($kw){//模糊查詢 搜尋結果     $where['title'] = array('like', $kw);     $results=$this->where($where)->order("value desc")->select();     return $results;}

三、更新站內瀏覽量

     public function update_seen($id){//更新站內瀏覽量         $arr=[$id,0];         $querys = array("_id"=>array('$in' => $arr));//為什麼我要這樣寫,而不直接$querys['_id']=$id呢,這是因為我串連的資料庫的_id並不是mongodb資料庫自動產生的,而是我們自訂的,而當你在用$querys['_id']時,thinkphp會自動將你的$id轉成ObjectId形式,但是$id本身無法轉換成ObjectId,就會導致報錯         $news=$this->where($querys)->find();         if ($news){             $seen=$news['seen']+0;             if ($seen==null or !$seen){                 $seen=0;             }             $data['seen']=$seen+1;             $querys = array("_id"=>array('$in' => $arr));             $this->where($querys)->save($data);         }     }
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.