码迷,mamicode.com
首页 > 数据库 > 详细

pcel安装的mongodb的两个问题的解决方案

时间:2017-05-08 21:02:07      阅读:237      评论:0      收藏:0      [点我收藏+]

标签:object   比较   参考   target   manager   option   记录   except   host   

  最近工作需要,要使用mongodb,这个是使用 pecl 安装的,跟标准的 mongo 使用还是有区别的,这里不讲区别,只讲两个比较典型的问题该如何处理,具体的文档大家可以直接参考 php 的官方文档:http://php.net/manual/zh/book.mongodb.php 

问题1: mongodb如何使用 _id 查询记录:

这里的id,是我们在插入一条记录时,mongo自动生成的id。

(1)从记录从获取id

function get_oid($query_result = array()){ // 这里的 $query_result 是查询到的一条记录
        if(empty($query_result)){
            return false;
        }else{
            $id_obj = $query_result[‘_id‘];
            $id_array = get_object_vars($id_obj);
            return $id_array[‘oid‘];
        }
}

(2)从 _id 查询相关记录

$id = new MongoDB\BSON\ObjectID($origin_id);  // $origin_id 为记录中的id
$query = array(‘_id‘ => $id); // $query为普通查询语句查询条件,利用该条件,就可以查询出 _id 为指定 id 的记录

 

问题2: 如何删除一个 collection

function drop_collection($db,$collection){
        $manager = new MongoDB\Driver\Manager(‘mongodb://‘.$your_hosts.‘/‘, $your_options); // 这里需要换为你的host option
        try{
            $server  = $manager->selectServer( new MongoDB\Driver\ReadPreference( MongoDB\Driver\ReadPreference::RP_PRIMARY ) );
            $result  = $server->executeCommand( $db, new MongoDB\Driver\Command(["drop" => $collection])); // 这句是实现的关键,注意格式
        }catch(Exception $E){
           return $E;
        }

        return $result;
}

 

pcel安装的mongodb的两个问题的解决方案

标签:object   比较   参考   target   manager   option   记录   except   host   

原文地址:http://www.cnblogs.com/smallrookie/p/6827066.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!