MongDB PHP7

PHP7 MongDB 安装与使用

本文教程只适合在 PHP7 的环境,如果你是 PHP5 环境,你可以参阅 PHP MongDB 安装与使用

PHP7 Mongdb 扩展安装

我们使用 pecl 命令来安装:

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

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

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

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

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

  1. $ 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 语法如下:

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

插入数据

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

  1. <?php
  2. $bulk = new MongoDB\Driver\BulkWrite;
  3. $document = ['_id' => new MongoDB\BSON\ObjectID, 'name' => 'mongodb教程'];
  4.  
  5. $_id= $bulk->insert($document);
  6.  
  7. var_dump($_id);
  8.  
  9. $manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");
  10. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);
  11. $result = $manager->executeBulkWrite('test.baidu', $bulk, $writeConcern);
  12. ?>

读取数据

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

  1. <?php
  2. $manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");
  3.  
  4. // 插入数据
  5. $bulk = new MongoDB\Driver\BulkWrite;
  6. $bulk->insert(['x' => 1, 'name'=>'baidu', 'url' => 'http://www.baidu.com']);
  7. $bulk->insert(['x' => 2, 'name'=>'Google', 'url' => 'http://www.google.com']);
  8. $bulk->insert(['x' => 3, 'name'=>'taobao', 'url' => 'http://www.taobao.com']);
  9. $manager->executeBulkWrite('test.sites', $bulk);
  10.  
  11. $filter = ['x' => ['$gt' => 1]];
  12. $options = [
  13. 'projection' => ['_id' => 0],
  14. 'sort' => ['x' => -1],
  15. ];
  16.  
  17. // 查询数据
  18. $query = new MongoDB\Driver\Query($filter, $options);
  19. $cursor = $manager->executeQuery('test.sites', $query);
  20.  
  21. foreach ($cursor as $document) {
  22. print_r($document);
  23. }
  24. ?>

输出结果为:

  1. stdClass Object
  2. (
  3. [x] => 3
  4. [name] => taobao
  5. [url] => http://www.taobao.com
  6. )
  7. stdClass Object
  8. (
  9. [x] => 2
  10. [name] => Google
  11. [url] => http://www.google.com
  12. )

更新数据

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

  1. <?php
  2. $bulk = new MongoDB\Driver\BulkWrite;
  3. $bulk->update(
  4. ['x' => 2],
  5. ['$set' => ['name' => 'baidu', 'url' => '123.baidu.com/webtools']],
  6. ['multi' => false, 'upsert' => false]
  7. );
  8.  
  9. $manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");
  10. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);
  11. $result = $manager->executeBulkWrite('test.sites', $bulk, $writeConcern);
  12. ?>

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

删除数据

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

  1. <?php
  2. $bulk = new MongoDB\Driver\BulkWrite;
  3. $bulk->delete(['x' => 1], ['limit' => 1]); // limit 为 1 时,删除第一条匹配数据
  4. $bulk->delete(['x' => 2], ['limit' => 0]); // limit 为 0 时,删除所有匹配数据
  5. $manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");
  6. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);
  7. $result = $manager->executeBulkWrite('test.sites', $bulk, $writeConcern);
  8. ?>

更多使用方法请参考:http://php.net/manual/en/book.mongodb.php