MongDB PHP7

Posted NAVYSUMMER

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MongDB PHP7相关的知识,希望对你有一定的参考价值。

---恢复内容开始---

php7 Mongdb 扩展安装

我们使用 pecl 命令来安装:

$ /usr/local/php7/bin/pecl install mongodb

执行成功后,会输出以下结果:

……
Build process completed successfully
Installing \'/usr/local/php7/lib/php/extensions/no-debug-non-zts-20151012/mongodb.so\'
install ok: channel://pecl.php.net/mongodb-1.1.7
configuration option "php_ini" is not set to php.ini location
You should add "extension=mongodb.so" to php.ini

接下来我们打开 php.ini 文件,添加 extension=mongodb.so 配置。

可以直接执行以下命令来添加。

$ echo "extension=mongodb.so" >> `/usr/local/php7/bin/php --ini | grep "Loaded Configuration" | sed -e "s|.*:\\s*||"`

注意:以上执行的命令中 php7 的安装目录为 /usr/local/php7/,如果你安装在其他目录,需要相应修改 pecl 与 php 命令的路径。


Mongodb 使用

PHP7 连接 MongoDB 语法如下:

$manager = new MongoDB\\Driver\\Manager("mongodb://localhost:27017");

插入数据

将 name 为"W3Cschool教程" 的数据插入到 test 数据库的 w3cschool 集合中。

<?php
$bulk = new MongoDB\\Driver\\BulkWrite;
$document = [\'_id\' => new MongoDB\\BSON\\ObjectID, \'name\' => \'W3Cschool教程\'];

$_id= $bulk->insert($document);

var_dump($_id);

$manager = new MongoDB\\Driver\\Manager("mongodb://localhost:27017");  
$writeConcern = new MongoDB\\Driver\\WriteConcern(MongoDB\\Driver\\WriteConcern::MAJORITY, 1000);
$result = $manager->executeBulkWrite(\'test.w3cschool\', $bulk, $writeConcern);
?>

读取数据

这里我们将三个网址数据插入到 test 数据库的 sites 集合,并读取迭代出来:

<?php
$manager = new MongoDB\\Driver\\Manager("mongodb://localhost:27017");  

// 插入数据
$bulk = new MongoDB\\Driver\\BulkWrite;
$bulk->insert([\'x\' => 1, \'name\'=>\'W3Cschool教程\', \'url\' => \'http://www.w3cschool.cn\']);
$bulk->insert([\'x\' => 2, \'name\'=>\'Google\', \'url\' => \'http://www.google.com\']);
$bulk->insert([\'x\' => 3, \'name\'=>\'taobao\', \'url\' => \'http://www.taobao.com\']);
$manager->executeBulkWrite(\'test.sites\', $bulk);

$filter = [\'x\' => [\'$gt\' => 1]];
$options = [
    \'projection\' => [\'_id\' => 0],
    \'sort\' => [\'x\' => -1],
];

// 查询数据
$query = new MongoDB\\Driver\\Query($filter, $options);
$cursor = $manager->executeQuery(\'test.sites\', $query);

foreach ($cursor as $document) {
    print_r($document);
}
?>

输出结果为:

stdClass Object
(
    [x] => 3
    [name] => taobao
    [url] => http://www.taobao.com
)
stdClass Object
(
    [x] => 2
    [name] => Google
    [url] => http://www.google.com
)

更新数据

接下来我们将更新 test 数据库 sites 集合中 x 为 2 的数据:

<?php
$bulk = new MongoDB\\Driver\\BulkWrite;
$bulk->update(
    [\'x\' => 2],
    [\'$set\' => [\'name\' => \'w3cschool在线工具\', \'url\' => \'123.w3cschool.cn/webtools\']],
    [\'multi\' => false, \'upsert\' => false]
);

$manager = new MongoDB\\Driver\\Manager("mongodb://localhost:27017");  
$writeConcern = new MongoDB\\Driver\\WriteConcern(MongoDB\\Driver\\WriteConcern::MAJORITY, 1000);
$result = $manager->executeBulkWrite(\'test.sites\', $bulk, $writeConcern);
?>

接下来我们使用 "db.sites.find()" 命令查看数据的变化,x 为 2 的数据已经变成了w3cschool在线工具:

 

删除数据

以下实例删除了 x 为 1 和 x 为 2的数据,注意 limit 参数的区别:

<?php
$bulk = new MongoDB\\Driver\\BulkWrite;
$bulk->delete([\'x\' => 1], [\'limit\' => 1]);   // limit 为 1 时,删除第一条匹配数据
$bulk->delete([\'x\' => 2], [\'limit\' => 0]);   // limit 为 0 时,删除所有匹配数据

$manager = new MongoDB\\Driver\\Manager("mongodb://localhost:27017");  
$writeConcern = new MongoDB\\Driver\\WriteConcern(MongoDB\\Driver\\WriteConcern::MAJORITY, 1000);
$result = $manager->executeBulkWrite(\'test.sites\', $bulk, $writeConcern);
?>

---恢复内容结束---

以上是关于MongDB PHP7的主要内容,如果未能解决你的问题,请参考以下文章

MongDB入门系列--什么是MongDB?

爬取豆瓣电影储存到数据库MONGDB中以及反反爬虫

尝试使用 mongdb 在 discord.js 中查找用户被静音的次数

C# Mongdb 之MongDb.Driver的 UpdateReault 参数解析

C# Mongdb 之MongDb.Driver的 UpdateReault 参数解析

C# Mongdb 之MongDb.Driver的 UpdateReault 参数解析