当前位置: 首页 > news >正文

PHP 操作mongodb api大部分方法

<?php
/* PHP mongodb 
 * 全部curd操作
 * @author:xiaojiang
 * @date: 2014-10-27
 */
//查看 mongo类版本  1.30 以后版本使用 MongoClient 
//Mongo::VERSION;
/*连接*/
    $m = new Mongo("mongodb://localhost");
    //连接多台
    //$m = new Mongo("mongodb://localhost:27017,localhost:27018");
//选择数据库
$db = $m->selectDB("banggoCMS");
    //$db = $m->banggoCMS;
$col = $db->dbeleComment2014;

/*新增*/
/*
  $opt = array(
      'fsync' => 1 //默认为 false , false时当日志配置开启时和 j 参数的功能类似 否则写操作会等到数据完全同步到硬盘后...true则忽略执行结果
      //...
  )
*/
//$ret = $col->insert( array('pid'=>2 , 'content'=>'test123') , $opt );

/*更新*/
    //$set 
    //修改属性
    //$ret = $col->update( array('pid'=> 2 ), array('$set'=> array('content'=>'123456') ) );
    //$unset
    //删除某个属性$unset
    //$ret = $col->update( array('pid'=> 2 ), array('$unset'=> array('content'=>1 ,'contents'=>1) ) );
    //$push 
    //为某个属性 新增/更新 一条记录 若属性不存在则新增属性
    //$ret = $col->update( array('pid'=> 2 ), array('$push'=> array('contents'=> array('v'=>1) ) ) );
    //$pushall
    //批量增加数据
    //$ret = $col->update( array('pid'=> 2 ), array('$pushAll'=> array('contents'=> array(1,2,3,4) ) ) );
    //$addToSet
    //和push功能类似 与$push不同的是$addToSet会保证元素的唯一性,防止重复添加
    //$ret = $col->update( array('pid'=> 2 ), array('$addToSet'=> array('contents'=> 1 ) ) );
    //$pop
    //删除字段数组中的第一条记录 。mongodb 1.1及以后的版本可以用 2或-2来删除两条,
    //$ret = $col->update( array('pid'=> 2 ), array('$pop'=> array('contents'=> -1 ) ) );
    //$pull   index
    //$ret = $col->update( array('pid'=> 2 ), array('$pull'=> array( 'contents' => 2 ) ) );
    //$pullAll
    //$ret = $col->update( array('pid'=> 2 ), array('$pullAll'=> array( 'contents' => array(1,2,3,4) ) ) );
    //$inc  $代表子项中的自身
    //$ret = $col->update( array('contents'=> 3 ), array('$inc'=> array('contents.$' => 100 )  ) );
    //$代表子项中的匹配记录自身
        //删除
        //$ret = $col->update( array('contents'=> 8 ), array('$unset'=> array('contents.$' => 1 )  ) );
        //修改
        //$ret = $col->update( array('contents'=> 2 ), array('$set'=> array('contents.$' => 11 )  ) );
        //添加 PS:更新的节点要是数组类型
        //  $ret = $col->update( array('contents.v'=> 34 ), array('$push'=> array('contents.$.test' => array('t1'=>1 ,'t2'=>2) ) ));
    
/*删除*/ 
    //$ret = $col->remove( array('pid'=> 2 ) );
    //只删除一条
    //$ret = $col->remove( array('pid'=> 2 ) , array("justOne" => true));
/*查询*/
 //$ret = $col->find( array('pid'=>2 , 'content'=>'test123') );
 //子查询
    //$ret = $col->findOne( array('pid'=>2 , 'contents'=>  1 ) );
    //$ret = $col->findOne( array('pid'=>2 , 'contents.t'=>  5 ) );
    
//获取总数
//$t = $ret->count();
//越过多少
//$ret = $col->find( array('pid'=>2) )->skip( 10 );
//排序
//$ret = $col->find( array('pid'=>2) )->sort(array("a" => 1));
//返回字段
//$ret = $col->find( array('pid'=>2), array('content') );
//$ret = $col->find( array('pid'=>2), array('content' => 0 ) ); //忽略字段
//返回对象  php >= 5.1  iterator_to_array  
//var_dump( iterator_to_array( $ret ) );
//否则
//foreach( $ret  as $v){
//    var_dump( $v );
//}
//$ret = $col->findOne(array('pid'=>2 , 'content'=>'test123'));
// 直接返回数组


?>

 

相关文章:

  • tcpdump -i eth0 -n -vvv src or dst port 443
  • Exchange 2013 ServerComponent状态异常处理
  • Oracle Minus 取差集
  • winform窗体取消最大化双击标题最大化
  • 初识 Cloudera Impala
  • php文件遍历
  • 如何让开机时,电脑用户自动登录?
  • 控制台登录,提示证书错误
  • 不高兴的小明
  • iis浏览网页时提示无法显示 XML 页
  • mvc和三层架构到底有什么区别
  • Java代码Bug分析插件 FindBugs
  • 网址
  • CSharp学习视频分享与开发技术QQ交流群
  • Docker如何管理数据
  • Android 初级面试者拾遗(前台界面篇)之 Activity 和 Fragment
  • angular2开源库收集
  • CSS实用技巧干货
  • HomeBrew常规使用教程
  • Java 11 发布计划来了,已确定 3个 新特性!!
  • JavaScript HTML DOM
  • Java读取Properties文件的六种方法
  • js面向对象
  • JS专题之继承
  • PAT A1092
  • Spring Boot MyBatis配置多种数据库
  • Swift 中的尾递归和蹦床
  • 从零开始在ubuntu上搭建node开发环境
  • 对话:中国为什么有前途/ 写给中国的经济学
  • 力扣(LeetCode)56
  • 巧用 TypeScript (一)
  • 正则表达式
  • PostgreSQL 快速给指定表每个字段创建索引 - 1
  • 如何在 Intellij IDEA 更高效地将应用部署到容器服务 Kubernetes ...
  • #【QT 5 调试软件后,发布相关:软件生成exe文件 + 文件打包】
  • $.ajax()参数及用法
  • (BFS)hdoj2377-Bus Pass
  • (C语言)strcpy与strcpy详解,与模拟实现
  • (LeetCode 49)Anagrams
  • (Redis使用系列) Springboot 实现Redis消息的订阅与分布 四
  • (ros//EnvironmentVariables)ros环境变量
  • (附源码)spring boot火车票售卖系统 毕业设计 211004
  • (附源码)springboot车辆管理系统 毕业设计 031034
  • (附源码)计算机毕业设计SSM保险客户管理系统
  • (机器学习的矩阵)(向量、矩阵与多元线性回归)
  • (一)Java算法:二分查找
  • (一)为什么要选择C++
  • (最全解法)输入一个整数,输出该数二进制表示中1的个数。
  • .NET 8 编写 LiteDB vs SQLite 数据库 CRUD 接口性能测试(准备篇)
  • .NET CORE 3.1 集成JWT鉴权和授权2
  • .NET Core 版本不支持的问题
  • .NET Framework 服务实现监控可观测性最佳实践
  • .NET 服务 ServiceController
  • .Net的DataSet直接与SQL2005交互
  • .NET上SQLite的连接