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

}

}