欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP使用mongoclient簡單操作mongodb數據庫示例

 更新時間:2019年02月08日 09:49:28   作者:trouble-i-am-in  
這篇文章主要介紹了PHP使用mongoclient簡單操作mongodb數據庫,結合實例形式分析了php使用mongoclient針對MongoDB數據庫的連接、增刪改查及相關函數使用技巧,需要的朋友可以參考下

本文實例講述了PHP使用mongoclient簡單操作mongodb數據庫。分享給大家供大家參考,具體如下:

最好回到《mongodb shell基礎命令【進階篇】》,再來看這里的內容,否則有些東西我講的比較籠統(tǒng)。

好了,不廢話了,直接貼代碼吧,別害怕看代碼,基本每行都寫了注釋了

<!-- 
1、本文采用mongoClient類來實現mongodb的簡單操作,
2、需要事先熟悉《mongodb基礎命令——進階篇》的內容
3、其中更新數據部分只給出了一個$set的例子,但是跟操作命令是一樣的,注意理解與嘗試
4、在最下來有對函數進行簡單的介紹,其中的一些內容會在本人學習完后續(xù)章節(jié)后回來補充的
 -->

<?php
try {
  // 連接mongodb數據庫
  $mongo = new MongoClient();
  // 選擇數據庫
  $db_name=$mongo->test;
  // 或者這樣也可以
  // $db_name=$mongo->selectDB('test');
  // 選擇集合
  $collection_name=$db_name->student;
  // 或者和上面一樣
  // $collection_name=$$db_name->selectCollection('collection_name');
  echo '<pre>';
  // 查看全部dbs
  $dbs=$mongo->listDBs();
  // var_dump($dbs);
  $collections=$db_name->listCollections();
  // var_dump($collections);
  // 定義被插入的數據,而且php的數組形式與json格式類似,所以很容易理解
  $input = array(
   'name' =>'yang' ,
   'sex'=>'man',
   'sorce' => array(
   'math' =>60 ,
   'pe'=>30 
   )
   );
  // 插入數據,$result會顯示插入數據的結果
  // insert的第二個參數內容請看--函數1
  // $result=$collection_name->insert($input);
  // var_dump($result);
  // 查詢單條數據,跟shell命令里的findOne()一樣
  $findOne=$collection_name->findOne();
  // var_dump($findOne);
  // 查找全部數據,記住一點,find()函數的返回值不是跟findOne()函數一樣的數組。而是一個對象,所以不能直接
  // 打印出來,至于如何讀取其中的內容,可以使用foreach循環(huán)
  $find=$collection_name->find();
  // 可以跟mongo shell中一樣為find()函數傳遞第一個篩選參數
  $situation = array(
   'name' => 'yang', 
   );
  // 選擇返回的字段內容
  $field = array('sorce' => 1 );
  // 詳細解釋看--函數2
  $find=$collection_name->find($situation,$field);
  // while ($each=$find->getNext()) {
  // var_dump($each);
  // }
  $sort=$collection_name->find()->sort(array('math' => -1, ));
  $limit=$collection_name->find()->sort(array('math' => -1, ))->limit(2);
  $skip=$collection_name->find()->sort(array('math' => -1, ))->skip(2);
  $count=$collection_name->find()->sort(array('math' => -1, ))->count();
  // echo $count;
  // foreach ($skip as $value) {
  // var_dump($value);
  // }
  // 條件操作符的使用
  $situation2=array(
   // 注意這里字段的設置跟shell中一樣
   'item.quantity'=>array('$gt'=>5)
   );
  $gt=$db_name->orders->find($situation2);
  /**********************************************數據的更新*******************************************/
  // 注意,接下來這段代碼會更新整個匹配到的文檔,就跟update沒有使用$set一樣
  // 詳情查看函數3
  $update=$db_name->orders->update(
   array('_class'=>'com.mongo.model.Orders'),
   array('_class'=>'hello world')
   );
  // 注意$set的位置,是不是與shell命令中一致
  $update=$db_name->orders->update(
   array('_class'=>'com.mongo.model.Orders'),
   array('$set'=>array('_class'=>'hello world'))
   );
  // 從這里可以看到,如果會shell命令的話,那么這一節(jié)的重點就是將shell命令與php數組之間的相互轉化了
  /**********************************************數據的刪除*******************************************/
  // 刪除集合中的數據
  $remove=$db_name->orders->remove(array('_class'=>'com.mongo.model.Orders'));
  // 刪除整個集合
  $db_name->orders->drop();
  // 本來還有一些集合之間使用DBRef聯查以及GRidFS的內容的,但是那個還是等以后要用了再來補充好了
} catch (MongoConnectionException $e) {
  echo $e->getMessage();
}
?>

其中幾個函數的解釋

--------------------------函數1--------------------

插入數據函數 insert

$mongo->$db_name->$collection_name->insert($input.$options)

$option中的參數以及默認值

$option=array(
'fsync'=> false,
'j'  => false,
'w'  => 1,
'wtimeout'=>10000,
'timeout'=>10000
)

'fsync' 

這個參數設置為真時,php將會告訴mongodb將當前寫入數據直接寫入硬盤,即使還沒有全部從php文檔寫入mongodb數據庫

'j'

這個參數設置為真市,php將會告訴mongodb在數據插入成功之前就將本次修改寫入日志

'w'

如果設置成0,寫操作將不會被確認,在這里還不會深究

'wtimeout'

跟上面的'w'綁定使用的,后面會介紹的

'timeout'

客戶端等待服務器響應的超時時間,也就是如果php的服務器等待mongodb數據庫寫入數據的時間,如果超過了timeout規(guī)定的時間,就算本次寫入失敗

---------------------------函數2--------------------

篩選數據函數 find

$mongo->$db_name->$collection_name->find($situation,$field)

$situation可以為空,表示返回全部數據,也可以是一個數組,表示篩選條件,就跟mongodb命令一樣
$field也可以為空,表示返回全部字段,也可以跟第一個參數一樣,傳入數組,規(guī)定返回的字段

注意,即使上面使用$field限制返回字段,_id字段還是會自動返回的

---------------------------函數3--------------------

更新數據 update

$mongo->$db_name->$collection_name->update($criteria,$update,$option)

結合shell命令就很好理解了
$criteria 表示篩選進行更新的文檔
$update 就是要更新后的數據

$option=array(
'upsert'=>false,
'multiple'=>true,
'fsync'=>false,
'w'=>1,
'wtimeout'=>10000,
'timeout'=>10000
)

后幾個的作用在函數1里講過了就不贅述了,upsert為true表示如果當前文檔存在就更新,不存在就創(chuàng)建,multiple為真表示匹配該條件的文檔都會被更新,即不止更新滿足條件的一個文檔。

---------------------------函數3--------------------

刪除數據 remove

$mongo->$db_name->$collection_name->remove($remove,$option)

$remove表示跟find()第一個參數一樣的篩選條件

$option=array(
'justOne'=>false,
'fsync'=>false,
'w'=>1,
'j'=>false,
'wtimeout'=>10000,
'timeout'=>10000
)

上面有的我就不贅述了,justOne根據名字來,就一個,如果為true表示就刪除一個匹配$remove的文檔

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP+MongoDB數據庫操作技巧大全》、《PHP基于pdo操作數據庫技巧總結》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總

希望本文所述對大家PHP程序設計有所幫助。

相關文章

最新評論