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);
         }
     }

转载于:https://my.oschina.net/mickelfeng/blog/1568174

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值