<?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)
//$ret = $col->findone(array('pid'=>2 , 'content'=>'test123'));
// 直接返回陣列
?>
mongodb api程式設計
1,連線類 dbclientconnection bool autoreconnect false,dbclientreplicaset cp 0,double so timeout 0 引數 autoreconnect 自動重連 cp 副本集使用引數,可以不用關心 so timeout 超時時間 ...
php操作php檔案
聽起來有些暈吧?使用php來操作php頁面。有乙個小的用途,在乙個系統當中可能會有個別的小項不便存入資料庫,但是我們又要經常在其他頁面當中呼叫,而且還需要更新,那麼我們就可以用這種方式來解決。其中遇到幾個小問題,搞了俺半天時間才搞定 比如說 使用者需要更改某乙個標題,但是單獨為這個標題在建立乙個表,...
mysql php 操作 php操作mysql步驟
php操作mysql步驟 php操作mysql步驟 1.connect mysql connect localhost root 123456 or die 資料庫連線失敗。mysql error 鏈結mysql。2.mysql select db database connect 選擇鏈結的資料庫...