首页 > 代码库 > pcel安装的mongodb的两个问题的解决方案

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

  最近工作需要,要使用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的两个问题的解决方案