本文教程只在 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 配置。

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

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

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

插入数据

将 name 为"511遇见" 的数据插入到 test 数据库的 runoob 集合中。

  1. <?php
  2. $bulk = new MongoDB\Driver\BulkWrite;
  3. $document = ['_id' => new MongoDB\BSON\ObjectID, 'name' => '511遇见'];
  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.runoob', $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'=>'511遇见', 'url' => 'http://www.511yj.com']);
  7. $bulk->insert(['x' => 2, 'name'=>'baidu', 'url' => 'http://www.baidu.com']);
  8. $bulk->insert(['x' => 3, 'name'=>'bing', 'url' => 'http://www.bing.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. ?>

输出结果为:

stdClass Object
(
[x] => 3
[name] => bing
[url] => http://www.bing.com
)
stdClass Object
(
[x] => 2
[name] => baidu
[url] => http://www.baidu.com
)

更新数据

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

  1. <?php
  2. $bulk = new MongoDB\Driver\BulkWrite;
  3. $bulk->update(
  4.     ['x' => 2],
  5.     ['$set' => ['name' => '图像印记', 'url' => 'images.511yj.com']],
  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. ?>

删除数据

以下实例删除了 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.  
  6. $manager = new MongoDB\Driver\Manager("mongodb://localhost:27017");  
  7. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);
  8. $result = $manager->executeBulkWrite('test.sites', $bulk, $writeConcern);
  9. ?>

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

 
 
 

发布日期: 2016-08-22 作者: 511遇见

所属分类: Php 标签: MongoDB PHP7

php7安装mogodb的更多相关文章

  1. PHP7安装笔记

    PHP7安装笔记 时间 -- :: 喵了个咪 原文 http://www.hdj.me/php7-install-note 主题 PHP # 安装mcrypt yum install -y php-m ...

  2. linux下php7安装memcached、redis扩展

    linux下php7安装memcached.redis扩展 1.php7安装Memcached扩展 比如说我现在使用了最新的 Ubuntu 16.04,虽然内置了 PHP 7 源,但 memcache ...

  3. centos系统中php7安装memcached 扩展

    #编译安装php-7.1.16 #wget http://cn2.php.net/distributions/php-7.1.16.tar.gz#tar -zxvf php-7.1.16.tar.gz ...

  4. centos7,php7 安装mysqli扩展

    首先安装MySQL https://www.cnblogs.com/manzb/p/9560403.html   php7安装后没有安装mysqli扩展的话: 安装mysqli扩展 1.到php文件e ...

  5. 转:Windows下PHP7安装Redis和Redis扩展phpredis

    原文地址:Windows下PHP7安装Redis和Redis扩展phpredis Windows下PHP7安装Redis和Redis扩展phpredis 2016-06-08 17:53:00 标签: ...

  6. windows下php7安装redis扩展

    windows下php7安装redis扩展windows下开发用的wamp集成的环境,想装个php-redis扩展.php_redis.dll下载地址:https://pecl.php.net/pac ...

  7. 在centos7中为php7安装redis扩展

    在此之前一直是用php5.6,安装redis也没遇到啥问题,嗖嗖的就安装上了 更新php版本到php7后,编译的时候报错 include <ext/standard/php_smart_str. ...

  8. PHP7安装Memcache+Memcached缓存加速WordPress教程

    PHP7安装Memcache+Memcached缓存加速WordPress教程 2016年1月19日 6,691 Views 生活方式 PHP7最显著的变化就是性能的极大提升,已接近Facebook开 ...

  9. php7安装memcache 和 memcached 扩展

    php7安装memcache 和 memcached 扩展 标签(空格分隔): php memcache和memcached区别 memcache:http://pecl.php.net/packag ...

  10. 初学Swoole:PHP7安装Swoole的步骤

    本篇文章给大家带来的内容是关于初学Swoole:PHP7安装Swoole的步骤,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 环境 这里不在使用apache做为web server. ...

随机推荐

  1. Appium常见属性和命令

    from appium import webdriverimport time, tracebackdesired_caps = {}desired_caps['platformName'] = 'A ...

  2. codeforce C. Maximal Intersection

    http://codeforces.com/contest/1029/problem/C 从第一天吃晚饭做到第二天吃完饭--你无法想象我的代码曾经150行 o( ̄┰ ̄*)ゞ 找到所有线段最远的左边和最 ...

  3. Centos7提示Initial setup of CentOS Linux 7 (core)

    Initial setup of CentOS Linux 7 (core) 1) [x] Creat user 2) [!] License information (no user will be ...

  4. ubuntu下编译安装uWebSockets

    最近开始接触websocket,第一次装的时候,还是遇到了些问题,这里记录一下 1.从git下载uWebSockets 地址:https://github.com/uNetworking/uWebSo ...

  5. 关于MounRiver编译器配置的若干问题

    目录 一.在工程中单独设置预编译宏 二.将变量存放到指定RAM地址 三.串口打印浮点数 四.添加64位数据处理 五.使用math数学库 六.关闭仿真时自动清dataflash功能 七.配置printf ...

  6. Linux Conda 使用activate无法进入环境,但list中有环境的路径

    安装OpenFace时装了个miniconda,之后就进不去anaconda的其它环境了: (pfld) .....$ conda env list # conda environments: # / ...

  7. Java运算符(复习)

    运算符 运算符:对字面量或者变量进行操作的符号 表达式:用运算符把字面量或者变量连接起来,符合Java语法的式子就可以称为表达式. 算数运算符 符号 作用 + 加法作用 - 减法作用 * 乘法作用 / ...

  8. Telerik GridView ----Pdf

    ExportToPDF exporter = new ExportToPDF(this.radGridView1); exporter.FileExtension = "pdf"; ...

  9. antd 动态添加表格列 表格不更新

    原因:react 对比columns 数组为原数组,内存地址没变: 解决办法:用es6的扩展,生成新数组,添加操作列operateCol setTableColumns([...tableColums ...

  10. js检测数组是否有重复的数据,

    function(arr){ let hash={} for (const key in arr){ if(hash[arr[key]]){ return true } hash[arr[key]]= ...