<?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')); // 直接返回數組 ?>
