PHP 操作mongodb api大部分方法

2021-09-08 10:29:25 字數 3405 閱讀 8789

<?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 選擇鏈結的資料庫...