设为首页 加入收藏

TOP

PHP操作MongoDB技术总结(六)
2015-11-21 01:45:36 来源: 作者: 【 】 浏览:7
Tags:PHP 操作 MongoDB 技术 总结
n->find($where); /** 分页获取结果集 **/ $cursor = $collection->find()->limit(5)->skip(0); /** 排序 **/ $cursor = $collection->find()->sort(array(‘age’=>-1,’type’=>1)); ##1表示降序 -1表示升序,参数的先后影响排序顺序 /** 索引 **/ $collection->ensureIndex(array(‘age’ => 1,’type’=>-1)); #1表示降序 -1表示升序 $collection->ensureIndex(array(‘age’ => 1,’type’=>-1),array(‘background’=>true)); #索引的创建放在后台运行(默认是同步运行) $collection->ensureIndex(array(‘age’ => 1,’type’=>-1),array(‘unique’=>true)); #该索引是唯一的 /** * ensureIndex (array(),array(‘name’=>’索引名称’,'background’=true,’unique’=true)) * 详见:http://www.php.net/manual/en/mongocollection.ensureindex.php */ /** 取得查询结果 **/ $cursor = $collection->find(); $array=array(); foreach ($cursor as $id => $value) { $array[]=$value; } //************************* //** 文档聚类 **// //************************* //这东西没弄明白… $conn->close(); #关闭连接 /* 关系型数据库与MongoDB数据存储的区别 MySql数据 结构: CREATE TABLE IF NOT EXISTS `column`( `column_id` int(16) NOT NULL auto_increment COMMENT ‘主键’, `column_name` varchar(32) NOT NULL COMMENT ‘栏目名称’, PRIMARY KEY (`column_id`) ); CREATE TABLE IF NOT EXISTS `article`( `article_id` int(16) NOT NULL auto_increment COMMENT ‘主键’, `article_caption` varchar(15) NOT NULL COMMENT ‘标题’, PRIMARY KEY(`article_id`) ); CREATE TABLE IF NOT EXISTS `article_body`( `article_id` int(16) NOT NULL COMMENT ‘article.article_id’, `body` text COMMENT ‘正文’ ); MongoDB数据结构: $data=array( ‘column_name’ =>’default’, ‘article’ =>array( ‘article_caption’ => ‘xiaocai’, ‘body’ => ‘xxxxxxxxxx…’ ) ); $inc 如果记录的该节点存在,让该节点的数值加N;如果该节点不存在,让该节点值等 于N 设结构记录结构为 array(’a’=>1,’b’=>’t’),想让a加5,那么: $coll->update( array(’b’=>’t’), array(’$inc’=>array(’a’=>5)), ) $set 让某节点等于给定值 设结构记录结构为 array(’a’=>1,’b’=>’t’),b为加f,那么: $coll->update( array(’a’=>1), array(’$set’=>array(’b’=>’f’)), ) $unset 删除某节点 设记录结构为 array(’a’=>1,’b’=>’t’),想删除b节点,那么: $coll->update( array(’a’=>1), array(’$unset’=>’b’), ) $push 如果对应节点是个数组,就附加一个新的值上去;不存在,就创建这个数组,并附加一个值在这个数组上;如果 该节点不是数组,返回错误。 设记录结构为array(’a’=>array(0=>’haha’),’b’=& gt;1),想附加新数据到节点a,那么: $coll->update( array(’b’=>1), array(’$push’=>array(’a’=>’wow’)), ) 这 样,该记录就会成为:array(’a’=>array(0=>’haha’,1=>’wow’),’b’=>1) $pushAll 与$push类似,只是会一次附加多个数值到某节点 $addToSet 如果该阶段的数组中没有某值,就添加之 设记录结构为array(’a’=>array(0=& gt;’haha’),’b’=>1),如果想附加新的数据到该节点a,那么: $coll->update( array(’b’=>1), array(’$addToSet’=>array(’a’=>’wow’)), ) 如果在a节点中已经有了wow,那么就不会再添加新的,如果没有,就会为该节点添加新的item——wow。 $pop 设该记录为array(’a’=>array(0=>’haha’,1=& gt;’wow’),’b’=>1) 删除某数组节点的最后一个元素: $coll->update( array(’b’=>1), array(’$pop=>array(’a’=>1)), ) 删除某数组阶段的第一个元素 $coll->update( array(’b’=>1), array(’$pop=>array(’a’=>-1)), ) $pull 如果该节点是个数组,那么删除其值为value的子项,如果不是数组,会返回一个错误。 设该记录为 array(’a’=>array(0=>’haha’,1=>’wow’),’b’=>1),想要删除a中value为 haha的子项: $coll->update( array(’b’=>1), array(’$pull=>array(’a’=>’haha’)), ) 结 果为: array(’a’=>array(0=>’wow’),’b’=>1) $pullAll 与$pull类似,只是可以删除一组符合条件的记录。 */ ?>
首页 上一页 3 4 5 6 下一页 尾页 6/6/6
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇分布式缓存GemFire架构介绍 下一篇【MongoDB】-用户权限设置详解

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: