PHP 操作mongodb api大部分方法

<?php
/* PHP mongodb
 * 全部curd操作
 * @author:xiaojiang
 * @date: 2014-10-27
 */
//查看 mongo类版本  1.30 以后版本使用 MongoClient
//Mongo::VERSION;
/*连接*/
    $m = new Mongo("mongodb://cms:[email protected]:55555/banggoCMS");
    //连接多台
    //$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‘));
// 直接返回数组

?>
时间: 2024-12-12 06:30:33

PHP 操作mongodb api大部分方法的相关文章

nodejs操作mongodb数据库的方法

//http://mongodb.github.io/node-mongodb-native/3.0/quick-start/quick-start/ /* nodejs操作mongodb数据库 1.安装mongodb. cnpm install mongodb --save 2.引入mongodb下面的MongoClient var MongoClient = require('mongodb').MongoClient; 3.定义数据库连接的地址 以及配置数据库 qianfeng数据库的名称

Java操作mongoDB2.6的常见API使用方法

对于mongoDB而言,学习方式和学习关系型数据库差不太多 開始都是学习怎样insert.find.update.remove,然后就是分页.排序.索引,再接着就是主从复制.副本集.分片等等 最后就是通过它提供的各个驱动(比方Java.PHP.node.js等等)来练习所谓的高级使用方法 另外:相对于Oracle有PLSQL Developer,MySQL有HeidiSQL mongoDB也不例外,它的图形化工具中有一款叫做mongoVUE的,我用的是1.5.3破解版(不是每15天就得改一次注冊

Python删除mongodb数据库和用户,查看Python操作mongodb的方法

#!/usr/bin/env python #coding:utf-8 from pymongo import MongoClient client = MongoClient('192.168.6.243', 27017) db=client['admin'] db.authenticate('root','123456') #help(db) #查看python操作mongodb的方法 for i in range(2,900): try: db = client['s%s' % i] db

学习MongoDB--(11):应用举例(利用java操作MongoDB)

原文地址:http://blog.csdn.net/drifterj/article/details/7948090 目录地址:http://blog.csdn.net/DrifterJ/article/category/1191327/2 前面我们都是通过shell来操作存取MongoDB的数据,shell中使用的语言就是javascript.我们这次说一下如何通过Java来访问操作MongoDB数据库的. Java驱动程序是MongoDB最早的驱动,已用于生产环境很长时间,十分稳定.可以到M

【转】PHP操作MongoDB GridFS 存储文件

PHP操作MongoDB GridFS 存储文件,如图片文件 GridFS是MongoDB的一个内置功能,它提供一组文件操作的API以利用MongoDB存储文件,GridFS的基本原理是将文件保存在两个Collection中,一个保存文件索引,一个保存文件内容,文件内容按一定大小分成若干块,每一块存在一个Document中,这种方法不仅提供了文件存储,还提供了对文件相关的一些附加属性(比如MD5值,文件名等等)的存储.

java操作mongoDB实现CURD

java操作mongoDB mongoDB作为一个牛气哄哄的nosql内存数据库,的确有很多优点,对于大数据量.高并发.弱事务的互联网应用,MongoDB可以应对自如.接触到mongoDB 参考了下api实现了增删改查.mongoDB 是面向对象设计,不用写sql语句 直接操作api 方法 就可以实现,这会儿数据库语句写不好的娃娃们有福了.直接贴码: DataTest.java package com.zk.db; import java.net.UnknownHostException; im

PHP操作MongoDB GridFS 存储文件,如图片文件

GridFS是MongoDB的一个内置功能,它提供一组文件操作的API以利用MongoDB存储文件,GridFS的基本原理是将文件保存在两个Collection中,一个保存文件索引,一个保存文件内容,文件内容按一定大小分成若干块,每一块存在一个Document中,这种方法不仅提供了文件存储,还提供了对文件相关的一些附加属性(比如MD5值,文件名等等)的存储. 01 <?php 02 // 初始化gridfs 03 $conn = new Mongo(); // 连接MongoDB 04 $db

atitit.api设计&#160;方法 指南 手册 v2 q929.docx

atitit.api设计 方法 指南 手册 v2 q929.docx atitit.api设计原则与方法 1. 归一化(锤子钉子理论)1 1.1. 链式方法2 1.2. 规则5:建立返回值类型2 1.3. 参数接收 JSON 对象2 1.4. 参数默认值2 1.5. 命名参数 support by map2 1.6.  处理类型 类型自动转换4 1.7.  处理 undefined null  empty5 1.8. .使用结构化语法5 1.9. 设置和获取操作,可以合二为一:方法越多,文档可能

mongoose - 让node.js高效操作mongodb

Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为JavaScript对象以供你在应用中使用. 当然要使用的话,必须要先安装好环境Node.js与MongoDB => MongoDB安装 MongoDB是目前最流行的noSQL数据库之一,它是专为node.js而开发的,理解下与我们常用的RDBMS关系型数据库的区别就可以基本使用了 MongoDB中有三个基本的概念区别于RDBMS 数据库:数