参考:https://www.php.net/manual/zh/class.mongodb-driver-manager.php

参考:https://www.zhaokeli.com/article/8574.html

Driver\Manager 入口文件,一般都要先实例化该类
Driver\BulkWrite 读写类,数据库的增、删、改都要先靠该类来实现
Driver\Query 查询类,MongoDB支持丰富的查询方式,所以单独拿出来组建了一个类
Driver\Cursor 返回结果类,其实就是一个Cursor类的一个对象,该类有内置的toArray()函数可以结果转换成数组形式的
BSON\ObjectID MongoDB默认创建的索引是_id,在添加的时候可以指定_id,给类就是可以创建一个指定内容的_id

我使用上述类简单操作MongoDB的时运行的顺序是:

实例化Manager类
要进行增删改操作时,实例化BulkWrite类,并根据需要的操作执行该类中的insert、delete、update方法,要进行查询时,实例化Query类
接着根据2中的操作,选择运行Manager类的executeQuery或者executeBulkWrite两个操作中的一个,返回结果类型是Cursor类,运行Cursor类的toArray方法,就能将结果从对象转换成数组,虽然其中还是会包含对象,但是比起单纯处理对象无疑是方便多了的。
这里贴一个基础操作类,把上面的过程进行了整合:

class MongoDBOperate
{
private $config = array(
'host' => '127.0.0.1',
'port' => '',
'user' => '',
'passwords' => '',
'db' => 'test'
);
// MongoDB\Driver入口类
private $Manage;
function __construct()
{
try {
$this->Manage = new MongoDB\Driver\Manager("mongodb://" . $this->config['host'] . "/" . $this->config['port']);
} catch (Exception $exception) {
echo $exception->getMessage();
}
} /**
* @param $collection
* @param $data
* @return array
* 新增数据
*/
public function insert($collection, $data)
{
// 返回结果_id
$_ids = array();
$BulkWrite = new MongoDB\Driver\BulkWrite();
if (is_array(current($data))) {
foreach ($data as $key => $datum) {
$_id = new MongoDB\BSON\ObjectID();
$datum['_id'] = $_id;
$BulkWrite->insert($datum);
$_ids[] = $_id->oid;
}
} else {
$_id = new MongoDB\BSON\ObjectID();
$data['_id'] = $_id;
$BulkWrite->insert($data);
$_ids = $_id->oid;
}
$this->Manage->executeBulkWrite($this->config['db'] . "." . $collection, $BulkWrite);
return $_ids;
} /**
* @param $collection
* @param $filter
* 删除数据
*/
public function delete($collection,$filter){
$BulkWrite=new MongoDB\Driver\BulkWrite();
if(is_array(current($filter))){
foreach ($filter as $key=>$value){
$BulkWrite->delete($value);
}
}else{
$BulkWrite->delete($filter);
}
$this->Manage->executeBulkWrite($this->config['db'].".".$collection,$BulkWrite);
} /**
* @param $collection
* @param $filter
* @param $data
* 更新数据
*/
public function update($collection,$filter,$data){
$BulkWrite=new MongoDB\Driver\BulkWrite();
if(is_array(current($filter))){
foreach ($filter as $key=>$value){
$BulkWrite->update($value,$data[$key]);
}
}else{
// var_dump($filter);
// var_dump($data);
$BulkWrite->update($filter,$data);
}
$this->Manage->executeBulkWrite($this->config['db'].".".$collection,$BulkWrite);
} /**
* @param $collection
* @param $filter
* @return array
* 查看数据
*/
public function select($collection,$filter){
$Query=new MongoDB\Driver\Query($filter);
$cursor=$this->Manage->executeQuery($this->config['db'].".".$collection,$Query);
return $cursor->toArray();
}
}

PHP使用MongoDB类操作MongoDB数据库总结的更多相关文章

  1. 42.QT-QSqlQuery类操作SQLite数据库(创建、查询、删除、修改)详解

    Qt 提供了 QtSql 模块来提供平台独立的基于 SQL 的数据库操作.这里我们所说的“平台 独立”,既包括操作系统平台,也包括各个数据库平台,Qt支持以下几种数据库: QT自带SQLITE数据库, ...

  2. [MongoDB]Python 操作 MongoDB

    from pymongo import MongoClient mc = MongoClient('localhost',27017) db = mc.users db.users.save({'na ...

  3. Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作

    2 Mongodb CRUD 操作 Mongodb Manual阅读笔记:CH2 Mongodb CRUD 操作Mongodb Manual阅读笔记:CH3 数据模型(Data Models)Mong ...

  4. 在MVC模式下通过Jqgrid表格操作MongoDB数据

    看到下图,是通过Jqgrid实现表格数据的基本增删查改的操作.表格数据增删改是一般企业应用系统开发的常见功能,不过不同的是这个表格数据来源是非关系型的数据库MongoDB.nosql虽然概念新颖,但是 ...

  5. nodejs操作mongodb数据库封装DB类

    这个DB类也算是我经历了3个实际项目应用的,现分享出来,有需要的请借鉴批评. 上面的注释都挺详细的,我使用到了nodejs的插件mongoose,用mongoose操作mongodb其实蛮方便的. 关 ...

  6. python操作MONGODB数据库,提取部分数据再存储

    目标:从一个数据库中提取几个集合中的部分数据,组合起来一共一万条.几个集合,不足一千条数据的集合就全部提取,够一千条的就用一万减去不足一千的,再除以大于一千的集合个数,得到的值即为所需提取文档的个数. ...

  7. C# Asp.net中简单操作MongoDB数据库(二)

    C# Asp.net中简单操作MongoDB数据库(一)    , mongodb数据库连接可以回顾上面的篇幅. 1.model类: public class BaseEntity { /// < ...

  8. C# Asp.net中简单操作MongoDB数据库(一)

    需要引用MongoDB.Driver.dll.MongoDB.Driver.core.dll.MongoDB.Bson.dll三个dll. 1.数据库连接: public class MongoDb ...

  9. PHP操作MongoDB数据库的示例

    http://www.jquerycn.cn/a_8137 本节内容:PHP操作MongoDB数据库的简单示例. Mongodb的常用操作参看手册,php官方的http://us2.php.net/m ...

随机推荐

  1. 批处理引擎MapReduce程序设计

    批处理引擎MapReduce程序设计 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MapReduce API Hadoop同时提供了新旧两套MapReduce API,新AP ...

  2. SpringCloud2.0 Turbine 断路器集群监控 基础教程(九)

    1.启动基础工程 1.1.启动[服务中心]集群,工程名称:springcloud-eureka-server 参考 SpringCloud2.0 Eureka Server 服务中心 基础教程(二) ...

  3. DNS服务概念

    DNS: Domain Name Service域名:www.magedu.com(主机名,FQDN:Full Qualified Domain Name, 完全限定域名)DNS:名称解析,Name ...

  4. mysql 5.6 rpm安装启动、配置参数、字符集修改等

    linux 7 安装mysql server 注意:此mysql版本是el6 MySQL-server-5.6.35-1.el6.x86_64 一.安装部署: 1.yum:首先要配置yum源,yum安 ...

  5. MySQL中的char与varchar详解

    mysql中char与varchar的区别: char:定长,效率高,一般用于固定长度的表单提交数据存储  :例如:身份证号,手机号,电话,密码等 varchar:不定长,效率偏低 1.varchar ...

  6. 《The One!团队》第八次作业:ALPHA冲刺(四)

    项目 内容 作业所属课程 所属课程 作业要求 作业要求 团队名称 < The One !> 作业学习目标 (1)掌握软件测试基础技术.(2)学习迭代式增量软件开发过程(Scrum) 第四天 ...

  7. 2-html标题、段落、换行与常用的字符实体

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  8. 【EF】vs2017中没有EF模型

    在添加->新建项目 中找不到实体模型? 或者 在vs中打开edmx文件时,显示的只有文本,没有图形模式 原因:是因为没有安装实体模型插件 解决方法: 1.打开网址 https://marketp ...

  9. leetcode解题报告(26):Add Binary

    描述 Given two binary strings, return their sum (also a binary string). For example, a = "11" ...

  10. fhq treap ------ luogu P3369 【模板】普通平衡树(Treap/SBT)

    二次联通门 : LibreOJ #104. 普通平衡树 #include <cstdio> #include <iostream> #include <algorithm ...