1. 程式人生 > >thinkphp開發總結(五)——mongodb的一些操作

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

一、應用場景:查詢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); } }