`
ljl_xyf
  • 浏览: 630421 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

用php实现mongoDB的基本操作

阅读更多

说到php连mongoDB,不得不先介绍一下php的官方手册,网址在:http://us.php.net/manual/en/book.mongo.php

在php的mongo扩展中,提供了4类接口(对象):

1,针对mongoDB连接的操作:Mongo

http://us.php.net/manual/en/class.mongo.php

2,针对mongoDB中数据库的操作:MongoDB

http://us.php.net/manual/en/class.mongodb.php

3,针对mongoDB中collection的操作:MongoCollection

http://us.php.net/manual/en/class.mongocollection.php

4,针对查询结果集的操作:MongoCursor

http://us.php.net/manual/en/class.mongocursor.php

与mongoDB建立连接:

直接实例化mongo类+创建连接:

$mo = new Mongo();//得到一个Mongo连接对象

实例化了一个Mongo类,并且与默认的localhost:27017端口的mongoDB建立连接。

如果想连接到其他的主机,可以这样写:$mongo = new Mongo("mongodb://username:password@192.168.1.22:12345");

另外一种方式,实例化mongo类,再手动建立连接:(http://www.my400800.cn )

$mongo = new Mongo("mongodb://username:password@192.168.1.22:12345",array('connect'=>false));//初始化类

$mongo->connect();//创建连接

Mongo类中有用的一些方法:

Mongo::listDBs()

http://us.php.net/manual/en/mongo.listdbs.php

返回一个包含当前mongo服务上的库(DB)信息的数组。

$mo = new Mongo();

$dbs = $mo->listDBs();//获得一个包含db信息的数组

Mongo::selectCollection($db,$coll)

http://us.php.net/manual/en/mongo.selectcollection.php

返回一个当前连接下的某db中的collection对象。

$mo = new Mongo();

$coll = $mo->selectCollection(’db’,'mycoll’);//得到一个collection对象

 

选择想要的数据库(Mongo类):

一种方式:

http://us.php.net/manual/en/mongo.get.php

$mongo = new Mongo();

$db = $mongo->foo;//得到一个MongoDB对象

另一种方式:

http://us.php.net/manual/en/mongo.selectdb.php

$mongo = new Mongo();

$db = $mongo->selectDB(’foo’);//得到一个MongoDB对象

MongoDB中有用的函数:

创建一个MongoDB对象

http://us.php.net/manual/en/mongodb.construct.php

$mo = new Mongo();

$db = new MongoDB($mo,’dbname’);//通过创建方式获得一个MongoDB对象

删除当前DB

http://us.php.net/manual/en/mongodb.drop.php

$db = $mo->dbname;

$db->drop();

获得当前数据库名

http://us.php.net/manual/en/mongodb.–tostring.php

$db = $mo->dbname;

$db->_tostring();

选择想要的collection:

A:

$mo = new Mongo();

$coll = $mo->dbname->collname;//获得一个collection对象

B:

$db = $mo->selectDB(’dbname’);

$coll = $db->collname;

C:

$db = $mo->dbname;

$coll = $db->selectCollectoin(’collname’);//获得一个collection对象

插入数据(MongoCollection对象):

http://us.php.net/manual/en/mongocollection.insert.php

MongoCollection::insert(array $a,array $options)

array $a 要插入的数组

array $options 选项

safe 是否返回操作结果信息

fsync 是否直接插入到物理硬盘

例程:

$coll = $mo->db->foo;

$a = array(’a'=>’b');

$options = array(’safe’=>true);

$rs  =$coll->insert($a,$options);

$rs为一个array型的数组,包含操作信息

删除数据库中的记录(MongoCollection对象):

http://us.php.net/manual/en/mongocollection.remove.php

MongoCollection::remove(array $criteria,array $options)

array $criteria  条件

array $options 选项

safe 是否返回操作结果

fsync 是否是直接影响到物理硬盘

justOne 是否只影响一条记录

例程:

$coll = $mo->db->coll;

$c = array(’a'=>1,’s’=>array(’$lt’=>100));

$options = array(’safe’=>true);

$rs = $coll->remove($c,$options);

$rs为一个array型的数组,包含操作信息

更新数据库中的记录(MongoCollection对象):

http://us.php.net/manual/en/mongocollection.update.php

MongoCollection::update(array $criceria,array $newobj,array $options)

array $criteria  条件

array $newobj 要更新的内容

array $options 选项

safe 是否返回操作结果

fsync 是否是直接影响到物理硬盘

upsert 是否没有匹配数据就添加一条新的

multiple 是否影响所有符合条件的记录,默认只影响一条

例程:

$coll = $mo->db->coll;

$c = array(’a'=>1,’s’=>array(’$lt’=>100));

$newobj = array(’e'=>’f',’x'=>’y');

$options = array(’safe’=>true,’multiple’=>true);

$rs = $coll->remove($c,$newobj,$options);

$rs为一个array型的数组,包含操作信息

查询collection获得单条记录(MongoCollection类):

http://us.php.net/manual/en/mongocollection.findone.php

array MongoCollection::findOne(array $query,array $fields)

array $query 条件

array $fields 要获得的字段

例程:

$coll = $mo->db->coll;

$query = array(’s’=>array(’$lt’=>100));

$fields = array(’a'=>true,’b'=>true);

$rs = $coll->findOne($query,$fields);

如果有结果就返回一个array,如果没有结果就返回NULL

查询collection获得多条记录(MongoCollection类):

http://us.php.net/manual/en/mongocollection.find.php

MongoCursor MongoCollection::find(array $query,array $fields)

array $query 条件

array $fields 要获得的字段

例程:

$coll = $mo->db->coll;

$query = array(’s’=>array(’$lt’=>100));

$fields = array(’a'=>true,’b'=>true);

$cursor = $coll->find($query,$fields);

返回一个游标记录对象MongoCursor。

针对游标对象MongoCursor的操作(MongoCursor类):

http://us.php.net/manual/en/class.mongocursor.php

循环或的结果记录:

$cursor = $coll->find($query,$fields);

while($cursor->hasNext()){

$r = $cursor->getNext();

var_dump($r);

}

或者

$cursor = $coll->find($query,$fields);

foreache($cursor as $k=>$v){

var_dump($v);

}

或者

$cursor = $coll->find($query,$fields);

$array= iterator_to_array($cursor);

一个血的教训:

http://us.php.net/manual/en/mongocursor.snapshot.php

 

 

在 我们做了find()操作,获得$cursor游标之后,这个游标还是动态的,也就是 在我获得游标到我循环操作完成对应记录的过程中,默认情况下,这对符合条件的记录如果增加,结果集也会自动增加。换句话说,在我find()之后,到我的 游标循环完成这段时间,如果再有符合条件的记录被插入到collection,那么这些记录也会被$cursor获得。

如果你想在获得$cursor之后的结果集不变化,需要这样做:

$cursor = $coll->find($query,$fields);

$cursor->snapshot();

foreache($cursor as $k=>$v){

var_dump($v);

}

下面让我们使用group操作,根据group_id分组,汇总计算count:

 

<?php

ini_set('mongo.native_long', 1);

$instance = new Mongo();

$instance = $instance->selectCollection('test', 'test');

$keys = array('group_id' => 1);

$initial = array('count' => 0);

$reduce = '
    function(obj, prev) {
        prev.count += obj.count;
    }
';

$result = $instance->group($keys, $initial, $reduce);

var_dump($result);

?>

结果和预想的有出入,count没有实现累加,而是变成了[object Object],目前,如果必须使用group操作,那么有两种方法可以缓解这个问题:

 

ini_set('mongo.native_long', 0);

 

$initial = array('count' => (float)0);

这两种方法都是治标不治本的权宜之计,既然当前PHP驱动里group的实现有问题,那我们就绕开它,用其它的方式实现同样的功能,这个方式就是MapReduce

 

<?php

ini_set('mongo.native_long', 1);

$instance = new Mongo();

$instance = $instance->selectDB('test');

$map = '
    function() {
        emit(this.group_id, this.count);
    }
';

$reduce = '
    function(key, values) {
        var sum = 0;

        for (var index in values) {
            sum += values[index];
        }

        return sum;
    }
';

$result = $instance->command(array(
    'mapreduce' => 'test',
    'map'       => $map,
    'reduce'    => $reduce
));

$result = iterator_to_array($instance->{$result['result']}->find());

var_dump($result);

?>

分享到:
评论

相关推荐

    MongoDB基本操作指南

    此外,MongoDB还提供了更新操作符,可以实现在服务器端的即时更新,减少客户端和服务端的通信,从而提高性能。例如,`upsert`选项可以在记录存在时更新,不存在时插入,这使得数据管理更为便捷。 在MongoDB中,CRUD...

    php Mongodb 操作类

    这个"php Mongodb操作类"是专为在PHP环境中与MongoDB数据库进行交互而设计的工具,允许开发者轻松地执行创建(Create)、读取(Read)、更新(Update)和删除(Delete)等基本数据库操作。 1. **MongoDB简介** ...

    PHP实现的MongoDB数据库操作类分享

    这个类提供了对MongoDB数据库的基本操作,如连接、选择数据库、创建索引等。 首先,`HMongodb`类中定义了几个私有成员变量: - `$mongo`:用于存储MongoDB的连接对象。 - `$curr_db_name`:当前选择的数据库名称。 ...

    php实现的mongodb操作类

    《PHP实现的MongoDB操作类详解》 MongoDB是一种基于分布式文件存储的开源数据库系统,以其灵活的数据模型、高性能和高可用性在现代Web开发中备受青睐。在PHP环境中,我们可以利用MongoDB的PHP驱动来操作MongoDB。...

    php+mvc+mongodb数据库基本操作

    在文件名为"mongo_mvc"的压缩包中,可能包含了实现PHP MVC架构的源码以及MongoDB的相关操作类,这些资源可以帮助初学者快速上手并理解PHP、MVC和MongoDB的结合使用。 总之,PHP的MVC模式和MongoDB数据库的结合使用...

    php操作MongoDB使用说明

    在PHP中操作MongoDB数据库主要依赖于PHP的MongoDB扩展。MongoDB是一个基于分布式文件存储的NoSQL数据库系统,适合处理大量数据并提供高可用性和高性能。本文将详细介绍如何使用PHP连接MongoDB、选择数据库、操作集合...

    PHP操作MONGODB详细文档 WORD版

    在IT行业中,数据库管理和开发是至关重要的技能,尤其是在大数据时代,NoSQL数据库如...通过阅读和实践,开发者不仅可以掌握基本的数据库操作,还能深入理解MongoDB的特性和PHP扩展的用法,从而在项目开发中游刃有余。

    php封装的mongodb操作类.zip

    这个“php封装的mongodb操作类”是为了解决PHP与MongoDB之间的交互问题,提供一套便捷的API,使得开发人员无需深入了解MongoDB的底层细节,就能完成诸如连接数据库、创建集合、插入文档、查询数据、更新和删除记录等...

    mongodb相关操作.txt

    ### MongoDB相关操作知识点 #### 一、环境搭建与配置 ...同时,也能够掌握如何安装MongoDB的PHP驱动器,从而实现MongoDB与PHP之间的交互。这些知识点对于使用MongoDB进行数据管理和处理非常重要。

    MongoDB PHP查找文档.pdf

    MongoDB 是一个流行的开源、分布式文档型数据库系统,它以JSON格式存储数据,非常适合处理半结构化和非结构化的数据。...通过理解并熟练运用这些基本的查询操作,你能够有效地构建和优化你的MongoDB应用。

    mongodb-1.6.0.tgz php扩展

    聚合框架则通过`MongoDB\Driver\AggregationCursor`来实现,支持对数据进行统计、过滤、分组等操作。 6. 其他特性:除了基本的数据库操作,PHP扩展还支持索引管理、权限控制、事件监听、性能监控等功能。例如,`...

    php-mongodb-redis手册

    4. PHP Redis扩展的使用:安装、配置和基本操作命令的介绍。 5. Redis数据类型的应用:如何根据业务需求选择合适的数据类型,并进行操作。 6. Redis高级功能:如发布/订阅、事务、持久化和复制等。 7. PHP与MongoDB/...

    PHP实现的mongoDB数据库操作类完整实例

    以下将详细介绍PHP如何操作MongoDB数据库,以及提供的数据库操作类的基本结构。 MongoDB的核心特性包括: 1. **面向集合存储**:MongoDB中的数据是以集合(Collections)的形式存储的,类似于关系数据库中的表。...

    PHP操作Mongodb封装类完整实例

    * Mongodb 基本操作API,支持基本类似关系统型数据库的操作接口 * * @version 1.0 * [说明] * * 1:该版本API实现了 Mongodb 中最基本的插入/修改/查询/删除操作的封装 * 2:其它更高级的操作可通过 $this-&gt;...

    mongodb驱动PHP版

    驱动程序是编程语言与数据库之间的桥梁,实现了必要的接口和函数,使得PHP代码能够与MongoDB通信。 MongoDB PHP驱动分为多个版本,以适应不同版本的PHP运行环境。例如,压缩包中的文件名如`...

    MongoDB and PHP.zip

    PHP与MongoDB的交互主要通过PHP的MongoDB扩展实现。在PHP 7之后,这个扩展被重命名为`mongodb`,并且引入了新的类和方法来操作MongoDB。例如,你可以使用`MongoDB\Client`创建一个连接实例,然后通过`selectDatabase...

    PHP操作MONGODB详细文档.docx

    以上步骤和知识点详细介绍了如何使用PHP操作MongoDB的基本流程和技术要点。无论是启动、配置、用户管理还是备份与恢复,这些操作都是日常运维工作中不可或缺的部分。通过对这些知识点的学习,可以帮助开发者更好地...

    mongodb和php的用法详解

    在PHP中连接MongoDB数据库的基本方法是使用MongoDB PHP驱动。首先,需要在PHP代码中创建一个新的MongoDB实例。如果使用默认连接本机的27017端口,可以简单地创建实例而不带任何参数。如果要连接远程主机,可以指定...

Global site tag (gtag.js) - Google Analytics