PHP实现的MongoDB数据增删改查

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

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

代码片段如下:

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

创建集合

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

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

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

集合创建成功


插入文档

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

插入文档代码片段如下:

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

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

数据插入成功

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

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

输出


    {
    "_id": ObjectId("57512b3a57c9150f178b4567"),
    "title" : "MongoDB",
    "description" : "database",
    "likes" : NumberLong(100),
    "url" : "http://www.mongodb.org.cn/",
    "by" : "Mongodb中文网"
    }

查找文档

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

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


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

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

MongoDB

更新文档

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

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


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

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

MongoDB 教程

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

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

输出


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

删除文档

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

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


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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值