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);
}
}
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。