原文地址:https://www.mongodb.org.cn/drivers/2.html   (该网站为mongoDB官方网站)

php中使用mongodb你必须使用 mongodb 的 php驱动。

MongoDB PHP在各平台上的安装及驱动包下载请查看:PHP安装MongoDB扩展驱动

如果你使用的是 PHP7,请参阅:PHP7 MongoDB 安装与使用

确保连接及选择一个数据库

为了确保正确连接,你需要指定数据库名,如果数据库在mongoDB中不存在,mongoDB会自动创建

代码片段如下:

  1. <?php
  2. $m = new MongoClient(); // 连接默认主机和端口为:mongodb://localhost:27017
  3. $db = $m->test; // 获取名称为 "test" 的数据库
  4. ?>

创建集合

创建集合的代码片段如下:

  1. <?php
  2. $m = new MongoClient(); // 连接
  3. $db = $m->test; // 获取名称为 "test" 的数据库
  4. $collection = $db->createCollection("mongo");
  5. echo "集合创建成功";
  6. ?>

执行以上程序,输出结果如下:

  1. 集合创建成功

插入文档

在mongoDB中使用 insert() 方法插入文档:

插入文档代码片段如下:

  1. <?php
  2. $m = new MongoClient(); // 连接到mongodb
  3. $db = $m->test; // 选择一个数据库
  4. $collection = $db->mongo; // 选择集合
  5. $document = array(
  6. "title" => "MongoDB",
  7. "description" => "database",
  8. "likes" => 100,
  9. "url" => "http://www.mongodb.org.cn/",
  10. "by" => "Mongodb中文网"
  11. );
  12. $collection->insert($document);
  13. echo "数据插入成功";
  14. ?>

执行以上程序,输出结果如下:

  1. 数据插入成功

然后我们在 mongo 客户端查看数据

  1. db.mongo.find().pretty();

输出

  1. {
  2. "_id": ObjectId("57512b3a57c9150f178b4567"),
  3. "title" : "MongoDB",
  4. "description" : "database",
  5. "likes" : NumberLong(100),
  6. "url" : "http://www.mongodb.org.cn/",
  7. "by" : "Mongodb中文网"
  8. }

查找文档

使用find() 方法来读取集合中的文档。

读取使用文档的代码片段如下:

  1. <?php
  2. $m = new MongoClient(); // 连接到mongodb
  3. $db = $m->test; // 选择一个数据库
  4. $collection = $db->runoob; // 选择集合
  5. $cursor = $collection->find(); // 迭代显示文档标题
  6. foreach ($cursor as $document) {
  7. echo $document["title"] . "\n";
  8. }
  9. ?>

执行以上程序,输出结果如下:

  1. MongoDB

更新文档

使用 update() 方法来更新文档。

以下实例将更新文档中的标题为' MongoDB 教程', 代码片段如下:

  1. <?php
  2. $m = new MongoClient(); // 连接到mongodb
  3. $db = $m->test; // 选择一个数据库
  4. $collection = $db->runoob; // 选择集合
  5. // 更新文档
  6. $collection->update(array("title"=>"MongoDB"), array('$set'=>array("title"=>"MongoDB 教程")));
  7. // 显示更新后的文档
  8. $cursor = $collection->find();
  9. // 循环显示文档标题
  10. foreach ($cursor as $document) {
  11. echo $document["title"] . "\n";
  12. }
  13. ?>

执行以上程序,输出结果如下:

  1. MongoDB 教程

然后我们在 mongo 客户端查看数据是否被更新

  1. db.runoob.find().pretty();

输出

  1. {
  2. "_id": ObjectId("57512b3a57c9150f178b4567"),
  3. "title" : "MongoDB教程",
  4. "description" : "database",
  5. "likes" : NumberLong(100),
  6. "url" : "http://www.mongodb.org.cn/",
  7. "by" : "Mongodb中文网"
  8. }

删除文档

使用 remove() 方法来删除文档。

以下实例中我们将移除 'title' 为 'MongoDB 教程' 的一条数据记录。, 代码片段如下:

  1. <?php
  2. $m = new MongoClient(); // 连接到mongodb
  3. $db = $m->test; // 选择一个数据库
  4. $collection = $db->mongo; // 选择集合
  5. // 移除文档
  6. $collection->remove(array("title"=>"MongoDB 教程"), array("justOne" => true));
  7. // 显示可用文档数据
  8. $cursor = $collection->find();
  9. foreach ($cursor as $document) {
  10. echo $document["title"] . "\n";
  11. }
  12. ?>

除了以上实例外,在php中你还可以使用findOne(), save(), limit(), skip(), sort()等方法来操作Mongodb数据库。

更多的操作方法可以参考 Mongodb 核心类:http://php.net/manual/zh/mongo.core.php

PHP实现的MongoDB数据增删改查的更多相关文章

  1. Java连接MongoDB进行增删改查

    1.导入必须的包: 详情看项目:http://pan.baidu.com/s/1cvDAOY 2.通过Myeclipse创建WEB项目 3. 3.bean:创建实体类 package com.bean ...

  2. MongoDB的增删改查 转

    MongoDB的增删改查 (黎明你好原创作品,转载请注明) MongoDB中数据的基本单元叫做文档,采用json的键-值的方式.多个键及其关联的值有序的存放在一起变是文档.类似于编程语言中的键值关系. ...

  3. Java实现mongodb原生增删改查语句

    Java实现mongodb原生增删改查语句 2018-03-16 自动化测试时,需校验数据库数据,为了快速自动化,在代码中用原生增删改查语句操作mongodb 结构 代码 0 pom.xml < ...

  4. Scala对MongoDB的增删改查操作

    =========================================== 原文链接: Scala对MongoDB的增删改查操作 转载请注明出处! ==================== ...

  5. C# 对MongoDB 进行增删改查的简单操作

    C# 对MongoDB 进行增删改查的简单操作   下面演示下C#操作MongoDB驱动的简单的增删改查代码 运用到的MongoDB支持的C#驱动,当前版本为1.6.0 1,连接数据库   /// & ...

  6. python操作三大主流数据库(8)python操作mongodb数据库②python使用pymongo操作mongodb的增删改查

    python操作mongodb数据库②python使用pymongo操作mongodb的增删改查 文档http://api.mongodb.com/python/current/api/index.h ...

  7. python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)

    一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...

  8. 2,MongoDB之增删改查及pymongo的使用

    本章我们来学习一下关于 MongoDB的增删改查 一.MongoDB操作 之 原生ORM,根本不存在SQL语句 创建数据库:这里和一般的关系型数据库一样,都要先建立一个自己的数据库空间 是的,Mong ...

  9. SpringBoot操作MongoDB实现增删改查

    本篇博客主讲如何使用SpringBoot操作MongoDB. SpringBoot操作MongoDB实现增删改查 (1)pom.xml引入依赖 <dependency> <group ...

随机推荐

  1. CSP-S 2019提高组训练 服务器需求

    时间限制:C/C++ 3秒 空间限制:C/C++ 262144K 题目描述 小多计划在接下来的n天里租用一些服务器,所有的服务器都是相同的.接下来n天中,第i天需要\(a_i\)台服务器工作,每台服务 ...

  2. 学习Microsoft Visio(2)

    常用业务设计图示法 一.业务设计基础 1.名词概念 业务流程图:在公司.部门.岗位的层面上描述一个业务流程的宏观过程. 基本流程图:对某个处理过程的详细逻辑流程进行描述. 静态业务对象图(UML表示法 ...

  3. JAVA项目部署到云服务器

    转自:(此处更详细)http://blog.csdn.net/gulu_gulu_jp/article/details/50994003 一.前言 前面我们已经尝过了在云服务器上部署代码的甜头了,现在 ...

  4. 让更多浏览器支持html5元素的简单方法

    当我们试图使用web上的新技术的时候,旧式浏览器总是我们心中不可磨灭的痛!事实上,所有浏览器都有或多或少的问题,现在还没有浏览器能够完整的识别和支持最新的html5结构元素.但是不用担心,你依然可以在 ...

  5. 走,去出海,一起“Copy to World” | 36氪出海行业报告

    http://www.sohu.com/a/200845344_114778 从工具类产品在海外聚集大量流量到新闻.社交游戏等内容类产品在海外取得优异成绩,中国正在完成从Copy to China向C ...

  6. LeetCode 1135. Connecting Cities With Minimum Cost

    原题链接在这里:https://leetcode.com/problems/connecting-cities-with-minimum-cost/ 题目: There are N cities nu ...

  7. java实现ssh登录linux服务器并下发命令

    依赖jar包:jsch-0.1.55.jar   commons-io-2.5.jar import com.jcraft.jsch.ChannelExec; import com.jcraft.js ...

  8. 洛谷 P3388 【模板】割点(割顶)题解

    今天学了割点,就A了这道板子,比较难理解的地方就在于如果是根节点就要找两个点来满足low[y]>=dfn[x],如果不是就只需找一个点来满足.Tarjan(i,i)中第一个i是开始搜索的点而第 ...

  9. 【转载】Visual Studio(VS) F12 查看DLL源代码

    https://www.cnblogs.com/zhaoqingqing/p/6751757.html esharper官网:https://www.jetbrains.com/resharper/ ...

  10. pgloader 学习(六) 加载csv 数据

    关于加载的配置参数都是使用comand file command file 参考格式 LOAD CSV FROM 'GeoLiteCity-Blocks.csv' WITH ENCODING iso- ...