加入收藏 | 设为首页 | 会员中心 | 我要投稿 唐山站长网 (https://www.0315zz.com.cn/)- 数据安全、数据开发、文字识别、图像处理、媒体智能!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP7 mongoDB扩展使用的方法分享

发布时间:2022-07-14 11:07:10 所属栏目:PHP教程 来源:互联网
导读:这篇文章主要给大家介绍了关于PHP7 mongoDB扩展使用的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用PHP7具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧。 前言 最近在做的项目需要将PHP5.6升级到PHP7.0,使用过PHP-mongo扩展的
  这篇文章主要给大家介绍了关于PHP7 mongoDB扩展使用的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用PHP7具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧。
 
  前言
 
  最近在做的项目需要将PHP5.6升级到PHP7.0,使用过PHP-mongo扩展的同学应该知道,PHP7.0的mongodb扩展是完全不兼容PHP5.6的mongo扩展的,php-mongodb改如何使用呢。
 
  下面直接说明各种方法的使用:
 
  1.mongodb连接:
 
  private function connect($confArr) {
   try{
    $connStr = "mongodb://" . $confArr['host'] . ":" . $confArr['port'] . "/" . $confArr['db_name'];
    $options = array(
     'username' => $confArr['username'],
     'password' => $confArr['password'],
     'readPreference' => $confArr['read_preference'],
     'connectTimeoutMS' => intval($confArr['connect_timeout_ms']),
     'socketTimeoutMS' => intval($confArr['socket_timeout_ms']),
    );
    $mc = new MongoDBDriverManager($connStr, $options);
    return $mc;
   }
   catch(Exception $e){
    return false;
   }
  }
  2.查询find:
 
  public function find($query = array(), $fields = array(), $collection, $sort = array(), $limit = 0, $skip = 0) {
   $conn = $this->connect();
   if (emptyempty($conn)) {
    return false;
   }
   try {
    $data = array();
    $options = array();
    if (!emptyempty($query)) {
     $options['projection'] = array_fill_keys($fields, 1);
    }
    if (!emptyempty($sort)) {
     $options['sort'] = $sort;
    }
    if (!emptyempty($limit)) {
     $options['skip'] = $skip;
     $options['limit'] = $limit;
    }
    $mongoQuery = new MongoDBDriverQuery($query, $options);
    $readPreference = new MongoDBDriverReadPreference(MongoDBDriverReadPreference::RP_SECONDARY);
    $cursor = $conn->executeQuery($collection, $mongoQuery, $readPreference);
    foreach($cursor as $value) {
     $data[] = (array)$value;
    }
    return $data;
   } catch (Exception $e) {
    //记录错误日志
   }
   return false;
  }
  3.插入操作insert:
 
  public function insert($addArr, $collection) {
   if (emptyempty($addArr) || !is_array($addArr)) {
    return false;
   }
   $conn = $this->connect();
   if (emptyempty($conn)) {
    return false;
   }
   try {
    $bulk = new MongoDBDriverBulkWrite();
    $bulk->insert($addArr);
    $writeConcern = new MongoDBDriverWriteConcern(MongoDBDriverWriteConcern::MAJORITY, 6000);
    $result = $conn->executeBulkWrite($collection, $bulk, $writeConcern);
    if ($result->getInsertedCount()) {
     return true;
    }
   } catch (Exception $e) {
    //记录错误日志
   }
   return false;
  }
  4.删除delete:
 
  public function delete($whereArr, $options = array(), $collection) {
   if (emptyempty($whereArr)) {
    return false;
   }
   if (!isset($options['justOne'])) {
    $options = array(
     'justOne' => false,
    );
   }
   $conn = $this->connect();
   if (emptyempty($conn)) {
    return false;
   }
   try {
    $bulk = new MongoDBDriverBulkWrite();
    $bulk->delete($whereArr, $options);
    $writeConcern = new MongoDBDriverWriteConcern(MongoDBDriverWriteConcern::MAJORITY, 30000);
    $result = $conn->executeBulkWrite($collection, $bulk, $writeConcern);
    return true;
   } catch (Exception $e) {
    //记录错误日志
   }
   return false;
  }
  5.执行command操作:
 
  private function command($params, $dbName) {
   $conn = $this->connect();
   if (emptyempty($conn)) {
    return false;
   }
   try {
    $cmd = new MongoDBDriverCommand($params);
    $result = $conn->executeCommand($dbName, $cmd);
    return $result;
   } catch (Exception $e) {
    //记录错误
   }
   return false;
  }
  6.统计count:
 
  public function count($query, $collection) {
   try {
    $cmd = array(
     'count' => $collection,
     'query' => $query,
    );
    $res = $this->command($cmd);
    $result = $res->toArray();
    return $result[0]->n;
   } catch (Exception $e) {
    //记录错误
   }
   return false;
  }
  7.聚合distinct:
 
  public function distinct($key, $where, $collection) {
   try {
    $cmd = array(
     'distinct' => $collection,
     'key' => $key,
     'query' => $where,
    );
    $res = $this->command($cmd);
    $result = $res->toArray();
    return $result[0]->values;
   } catch (Exception $e) {
    //记录错误
   }
   return false;
  }
  8.aggregate操作:
 
  public function aggregate($where, $group, $collection) {
   try {
    $cmd = array(
     'aggregate' => $collection,
     'pipeline' => array(
      array(
       '$match' => $where,
      ),
      array(
       '$group' => $group,
      ),
     ),
     'explain' => false,
    );
    $res = $this->command($cmd);
    if (!$res) {
     return false;
    }
    $result = $res->toArray();
    return $result[0]->total;
   } catch (Exception $e) {
    //记录错误
   }
   return false;
  }
 

(编辑:唐山站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读