首頁 php教程 php手册 php 操作mongodb

php 操作mongodb

Jun 06, 2016 pm 07:56 PM
mongodb php 操作

/** * PHP操作MongoDB学习笔记 */ //************************* //** 连接MongoDB数据库 **// //************************* //格式=(“mongodb://用户名:密码 @地址:端口/默认指定数据库”,参数) $conn = new Mongo(); //可以简写为 //$conn=new Mongo(); #

  

  /**

  * PHP操作MongoDB学习笔记

  */

  //*************************

  //** 连接MongoDB数据库 **//

  //*************************

  //格式=>(“mongodb://用户名:密码 @地址:端口/默认指定数据库”,参数)

  $conn = new Mongo();

  //可以简写为

  //$conn=new Mongo(); #连接本地主机,默认端口.

  //$conn=new Mongo(“172.21.15.69″); #连接远程主机

  //$conn=new Mongo(“xiaocai.loc:10086″); #连接指定端口远程主机

  //$conn=new Mongo(“xiaocai.loc”,array(“replicaSet”=>true)); #负载均衡

  //$conn=new Mongo(“xiaocai.loc”,array(“persist”=>”t”)); #持久连接

  //$conn=new Mongo(“mongodb://sa:123@localhost”); #带用户名密码

  //$conn=new Mongo(“mongodb://localhost:27017,localhost:27018″); #连接多个服务器

  //$conn=new Mongo(“mongodb:///tmp/mongo-27017.sock”); #域套接字

  //$conn=new Mongo(“mongodb://admin_miss:miss@localhost:27017/test”,array(‘persist’=>’p',”replicaSet”=>true)); #完整

  //详细资料:http://www.php.net/manual/en/mongo.connecting.php

  //*************************

  //** 选择数据库与表 **//

  //*************************

  $db=$conn->mydb; #选择mydb数据库

  //$db=$conn->selectDB(“mydb”); #第二种写法

  $collection=$db->column; #选择集合(选择’表’)

  //$collection=$db->selectCollection(‘column’); #第二种写法

  //$collection=$conn->mydb->column; #更简洁的写法

  //注意:1.数据库和集合不需要事先创建,若它们不存在则会自动创建它们.

  // 2.注意错别字,你可能会无意间的创建一个新的数据库(与原先的数据库混乱).

  //*************************

  //** 插入文档 **//

  //*************************

  //**向集合中插入数据,返回bool判断是否插入成功. **/

  $array=array(‘column_name’=>’col’.rand(100,999),’column_exp’=>’xiaocai’);

  $result=$collection->insert($array); #简单插入

  echo “新记录ID:”.$array['_id']; #MongoDB会返回一个记录标识

  var_dump($result); #返回:bool(true)

  //**向集合中安全插入数据,返回插入状态(数组). **/

  $array=array(‘column_name’=>’col’.rand(100,999),’column_exp’=>’xiaocai2′);

  $result=$collection->insert($array,true); #用于等待MongoDB完成操作,以便确定是否成功.(当有大量记录插入时使用该参数会比较有用)

  echo “新记录ID:”.$array['_id']; #MongoDB会返回一个记录标识

  var_dump($result); #返回:array(3) { ["err"]=> NULL ["n"]=> int(0) ["ok"]=> float(1) }

  //**完整的写法 **/

  #insert($array,array(‘safe’=>false,’fsync’=>false,’timeout’=>10000))

  /*

  * *

  * 完整格式:insert ( array $a [, array $options = array() ] )

  * insert(array(),array(‘safe’=>false,’fsync’=>false,’timeout’=>10000))

  * 参数:safe:默认false,是否安全写入

  * fsync:默认false,是否强制插入到同步到磁盘

  * timeout:超时时间(毫秒)

  *

  * 插入结果:{ “_id” : ObjectId(“4d63552ad549a02c01000009″), “column_name” : “col770″, “column_exp” : “xiaocai” }

  * ’_id’为主键字段,在插入是MongoDB自动添加.

  *

  * 注意:1.以下两次插入的为同一条记录(相同的_id),因为它们的值相同。

  * $collection->insert(array(‘column_name’=>’xiaocai’));

  * $collection->insert(array(‘column_name’=>’xiaocai’));

  * 避免

  * $collection->insert(array(‘column_name’=>’xiaocai’),true);

  * try {

  * $collection->insert(array(‘column_name’=>’xiaocai’),true);

  * }catch(MongoCursorException $e){

  * echo “Can’t save the same person twice!\n”;

  * }

  *

  * 详细资料:http://www.php.net/manual/zh/mongocollection.insert.php

  * *

  */

  //*************************

  //** 更新文档 **//

  //*************************

  //** 修改更新 **/

  $where=array(‘column_name’=>’col123′);

  $newdata=array(‘column_exp’=>’GGGGGGG’,'column_fid’=>444);

  $result=$collection->update($where,array(‘$set’=>$newdata)); #$set:让某节点等于给定值,类似的还有$pull $pullAll $pop $inc,在后面慢慢说明用法

  /*

  * 结果:

  * 原数据

  * {“_id”:ObjectId(“4d635ba2d549a02801000003″),”column_name”:”col123″,”column_exp”:”xiaocai”}

  * 被替换成了

  * {“_id”:ObjectId(“4d635ba2d549a02801000003″),”column_name”:”col123″,”column_exp”:”GGGGGGG”,”column_fid”:444}

  */

  //** 替换更新 **/

  $where=array(‘column_name’=>’col709′);

  $newdata=array(‘column_exp’=>’HHHHHHHHH’,'column_fid’=>123);

  $result=$collection->update($where,$newdata);

  /*

  * 结果:

  * 原数据

  * {“_id”:ObjectId(“4d635ba2d549a02801000003″),”column_name”:”col709″,”column_exp”:”xiaocai”}

  * 被替换成了

  * {“_id”:ObjectId(“4d635ba2d549a02801000003″),”column_exp”:”HHHHHHHHH”,”column_fid”:123}

  */

  //** 批量更新 **/

  $where=array(‘column_name’=>’col’);

  $newdata=array(‘column_exp’=>’multiple’,’91u’=>684435);

  $result=$collection->update($where,array(‘$set’=>$newdata),array(‘multiple’=>true));

  /**

  * 所有’column_name’='col’都被修改

  */

  //** 自动累加 **/

  $where=array(’91u’=>684435);

  $newdata=array(‘column_exp’=>’edit’);

  $result=$collection->update($where,array(‘$set’=>$newdata,’$inc’=>array(’91u’=>-5)));

  /**

  * 更新91u=684435的数据,并且91u自减5

  */

  /** 删除节点 **/

  $where=array(‘column_name’=>’col685′);

  $result=$collection->update($where,array(‘$unset’=>’column_exp’));

  /**

  * 删除节点column_exp

  */

  /*

  * *

  * 完整格式:update(array $criteria, array $newobj [, array $options = array() ] )

  * 注意:1.注意区分替换更新与修改更新

  * 2.注意区分数据类型如 array(’91u’=>’684435′)与array(’91u’=>684435)

  * 详细资料:http://www.mongodb.org/display/DOCS/Updating#Updating-%24bit

  * *

  */

  //*************************

  //** 删除文档 **//

  //*************************

  /** 清空数据库 **/

  $collection->remove(array(‘column_name’=>’col399′));

  //$collection->remove(); #清空集合

  /** 删除指定MongoId **/

  $id = new MongoId(“4d638ea1d549a02801000011″);

  $collection->remove(array(‘_id’=>(object)$id));

  /*

  * *

  * 使用下面的方法来匹配{“_id”:ObjectId(“4d638ea1d549a02801000011″)},查询、更新也一样

  * $id = new MongoId(“4d638ea1d549a02801000011″);

  * array(‘_id’=>(object)$id)

  * *

  */

  //*************************

  //** 查询文档 **//

  //*************************

  /** 查询文档中的记录数 **/

  echo ‘count:’.$collection->count().”
”; #全部

  echo ‘count:’.$collection->count(array(‘type’=>’user’)).”
”; #可以加上条件

  echo ‘count:’.$collection->count(array(‘age’=>array(‘$gt’=>50,’$lte’=>74))).”
”; #大于50小于等于74

  echo ‘count:’.$collection->find()->limit(5)->skip(0)->count(true).”
”; #获得实际返回的结果数

  /**

  * 注:$gt为大于、$gte为大于等于、$lt为小于、$lte为小于等于、$ne为不等于、$exists不存在

  */

  /** 集合中所有文档 **/

  $cursor = $collection->find()->snapshot();

  foreach ($cursor as $id => $value) {

  echo “$id: “; var_dump($value); echo “
”;

  }

  /**

  * 注意:

  * 在我们做了find()操作,获得$cursor游标之后,这个游标还是动态的.

  * 换句话说,在我find()之后,到我的游标循环完成这段时间,如果再有符合条件的记录被插入到collection,那么这些记录也会被$cursor 获得.

  * 如果你想在获得$cursor之后的结果集不变化,需要这样做:

  * $cursor = $collection->find();

  * $cursor->snapshot();

  * 详见http://www.bumao.com/index.php/2010/08/mongo_php_cursor.html

  */

  /** 查询一条数据 **/

  $cursor = $collection->findOne();

  /**

  * 注意:findOne()获得结果集后不能使用snapshot(),fields()等函数;

  */

  /** age,type 列不显示 **/

  $cursor = $collection->find()->fields(array(“age”=>false,”type”=>false));

  /** 只显示user 列 **/

  $cursor = $collection->find()->fields(array(“user”=>true));

  /**

  * 我这样写会出错:$cursor->fields(array(“age”=>true,”type”=>false));

  */

  /** (存在type,age节点) and age!=0 and age

  $where=array(‘type’=>array(‘$exists’=>true),’age’=>array(‘$ne’=>0,’$lt’=>50,’$exists’=>true));

  $cursor = $collection->find($where);

  /** 分页获取结果集 **/

  $cursor = $collection->find()->limit(5)->skip(0);

  /** 排序 **/

  $cursor = $collection->find()->sort(array(‘age’=>-1,’type’=>1)); ##1表示降序 -1表示升序,参数的先后影响排序顺序

  /** 索引 **/

  $collection->ensureIndex(array(‘age’ => 1,’type’=>-1)); #1表示降序 -1表示升序

  $collection->ensureIndex(array(‘age’ => 1,’type’=>-1),array(‘background’=>true)); #索引的创建放在后台运行(默认是同步运行)

  $collection->ensureIndex(array(‘age’ => 1,’type’=>-1),array(‘unique’=>true)); #该索引是唯一的

  /**

  * ensureIndex (array(),array(‘name’=>’索引名称’,'background’=true,’unique’=true))

  * 详见:http://www.php.net/manual/en/mongocollection.ensureindex.php

  */

  /** 取得查询结果 **/

  $cursor = $collection->find();

  $array=array();

  foreach ($cursor as $id => $value) {

  $array[]=$value;

  }

  //*************************

  //** 文档聚类 **//

  //*************************

  //这东西没弄明白…

  $conn->close(); #关闭连接

  /*

  关系型数据库与MongoDB数据存储的区别

  MySql数据结构:

  CREATE TABLE IF NOT EXISTS `column`(

  `column_id` int(16) NOT NULL auto_increment COMMENT ‘主键’,

  `column_name` varchar(32) NOT NULL COMMENT ‘栏目名称’,

  PRIMARY KEY (`column_id`)

  );

  CREATE TABLE IF NOT EXISTS `article`(

  `article_id` int(16) NOT NULL auto_increment COMMENT ‘主键’,

  `article_caption` varchar(15) NOT NULL COMMENT ‘标题’,

  PRIMARY KEY(`article_id`)

  );

  CREATE TABLE IF NOT EXISTS `article_body`(

  `article_id` int(16) NOT NULL COMMENT ‘article.article_id’,

  `body` text COMMENT ‘正文’

  );

  MongoDB数据结构:

  $data=array(

  ‘column_name’ =>’default’,

  ‘article’ =>array(

  ‘article_caption’ => ‘xiaocai’,

  ‘body’ => ‘xxxxxxxxxx…’

  )

  );

  $inc

  如果记录的该节点存在,让该节点的数值加N;如果该节点不存在,让该节点值等于N

  设结构记录结构为 array(’a’=>1,’b’=>’t’),想让a加5,那么:

  $coll->update(

  array(’b’=>’t’),

  array(’$inc’=>array(’a’=>5)),

  )

  $set

  让某节点等于给定值

  设结构记录结构为 array(’a’=>1,’b’=>’t’),b为加f,那么:

  $coll->update(

  array(’a’=>1),

  array(’$set’=>array(’b’=>’f’)),

  )

  $unset

  删除某节点

  设记录结构为 array(’a’=>1,’b’=>’t’),想删除b节点,那么:

  $coll->update(

  array(’a’=>1),

  array(’$unset’=>’b’),

  )

  $push

  如果对应节点是个数组,就附加一个新的值上去;不存在,就创建这个数组,并附加一个值在这个数组上;如果该节点不是数组,返回错误。

  设记录结构为array(’a’=>array(0=>’haha’),’b’=& gt;1),想附加新数据到节点a,那么:

  $coll->update(

  array(’b’=>1),

  array(’$push’=>array(’a’=>’wow’)),

  )

  这样,该记录就会成为:array(’a’=>array(0=>’haha’,1=>’wow’),’b’=>1)

  $pushAll

  与$push类似,只是会一次附加多个数值到某节点

  $addToSet

  如果该阶段的数组中没有某值,就添加之

  设记录结构为array(’a’=>array(0=& gt;’haha’),’b’=>1),如果想附加新的数据到该节点a,那么:

  $coll->update(

  array(’b’=>1),

  array(’$addToSet’=>array(’a’=>’wow’)),

  )

  如果在a节点中已经有了wow,那么就不会再添加新的,如果没有,就会为该节点添加新的item――wow。

  $pop

  设该记录为array(’a’=>array(0=>’haha’,1=& gt;’wow’),’b’=>1)

  删除某数组节点的最后一个元素:

  $coll->update(

  array(’b’=>1),

  array(’$pop=>array(’a’=>1)),

  )

  删除某数组阶段的第一个元素

  $coll->update(

  array(’b’=>1),

  array(’$pop=>array(’a’=>-1)),

  )

  $pull

  如果该节点是个数组,那么删除其值为value的子项,如果不是数组,会返回一个错误。

  设该记录为 array(’a’=>array(0=>’haha’,1=>’wow’),’b’=>1),想要删除a中value为 haha的子项:

  $coll->update(

  array(’b’=>1),

  array(’$pull=>array(’a’=>’haha’)),

  )

  结果为: array(’a’=>array(0=>’wow’),’b’=>1)

  $pullAll

  与$pull类似,只是可以删除一组符合条件的记录。

  */

  ?>

  

  /**

  * PHP操作MongoDB学习笔记

  */

  //*************************

  //** 连接MongoDB数据库 **//

  //*************************

  //格式=>(“mongodb://用户名:密码 @地址:端口/默认指定数据库”,参数)

  $conn = new Mongo();

  //可以简写为

  //$conn=new Mongo(); #连接本地主机,默认端口.

  //$conn=new Mongo(“172.21.15.69″); #连接远程主机

  //$conn=new Mongo(“xiaocai.loc:10086″); #连接指定端口远程主机

  //$conn=new Mongo(“xiaocai.loc”,array(“replicaSet”=>true)); #负载均衡

  //$conn=new Mongo(“xiaocai.loc”,array(“persist”=>”t”)); #持久连接

  //$conn=new Mongo(“mongodb://sa:123@localhost”); #带用户名密码

  //$conn=new Mongo(“mongodb://localhost:27017,localhost:27018″); #连接多个服务器

  //$conn=new Mongo(“mongodb:///tmp/mongo-27017.sock”); #域套接字

  //$conn=new Mongo(“mongodb://admin_miss:miss@localhost:27017/test”,array(‘persist’=>’p',”replicaSet”=>true)); #完整

  //详细资料:http://www.php.net/manual/en/mongo.connecting.php

  //*************************

  //** 选择数据库与表 **//

  //*************************

  $db=$conn->mydb; #选择mydb数据库

  //$db=$conn->selectDB(“mydb”); #第二种写法

  $collection=$db->column; #选择集合(选择’表’)

  //$collection=$db->selectCollection(‘column’); #第二种写法

  //$collection=$conn->mydb->column; #更简洁的写法

  //注意:1.数据库和集合不需要事先创建,若它们不存在则会自动创建它们.

  // 2.注意错别字,你可能会无意间的创建一个新的数据库(与原先的数据库混乱).

  //*************************

  //** 插入文档 **//

  //*************************

  //**向集合中插入数据,返回bool判断是否插入成功. **/

  $array=array(‘column_name’=>’col’.rand(100,999),’column_exp’=>’xiaocai’);

  $result=$collection->insert($array); #简单插入

  echo “新记录ID:”.$array['_id']; #MongoDB会返回一个记录标识

  var_dump($result); #返回:bool(true)

  //**向集合中安全插入数据,返回插入状态(数组). **/

  $array=array(‘column_name’=>’col’.rand(100,999),’column_exp’=>’xiaocai2′);

  $result=$collection->insert($array,true); #用于等待MongoDB完成操作,以便确定是否成功.(当有大量记录插入时使用该参数会比较有用)

  echo “新记录ID:”.$array['_id']; #MongoDB会返回一个记录标识

  var_dump($result); #返回:array(3) { ["err"]=> NULL ["n"]=> int(0) ["ok"]=> float(1) }

  //**完整的写法 **/

  #insert($array,array(‘safe’=>false,’fsync’=>false,’timeout’=>10000))

  /*

  * *

  * 完整格式:insert ( array $a [, array $options = array() ] )

  * insert(array(),array(‘safe’=>false,’fsync’=>false,’timeout’=>10000))

  * 参数:safe:默认false,是否安全写入

  * fsync:默认false,是否强制插入到同步到磁盘

  * timeout:超时时间(毫秒)

  *

  * 插入结果:{ “_id” : ObjectId(“4d63552ad549a02c01000009″), “column_name” : “col770″, “column_exp” : “xiaocai” }

  * ’_id’为主键字段,在插入是MongoDB自动添加.

 

[1] [2] 

php 操作mongodb

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

說明匹配表達式(PHP 8)及其與開關的不同。 說明匹配表達式(PHP 8)及其與開關的不同。 Apr 06, 2025 am 12:03 AM

在PHP8 中,match表達式是一種新的控制結構,用於根據表達式的值返回不同的結果。 1)它類似於switch語句,但返回值而非執行語句塊。 2)match表達式使用嚴格比較(===),提升了安全性。 3)它避免了switch語句中可能的break遺漏問題,增強了代碼的簡潔性和可讀性。

什麼是跨站點偽造(CSRF),您如何在PHP中實施CSRF保護? 什麼是跨站點偽造(CSRF),您如何在PHP中實施CSRF保護? Apr 07, 2025 am 12:02 AM

在PHP中可以通過使用不可預測的令牌來有效防範CSRF攻擊。具體方法包括:1.生成並在表單中嵌入CSRF令牌;2.在處理請求時驗證令牌的有效性。

您如何防止班級被擴展或方法在PHP中被覆蓋? (最終關鍵字) 您如何防止班級被擴展或方法在PHP中被覆蓋? (最終關鍵字) Apr 08, 2025 am 12:03 AM

在PHP中,final關鍵字用於防止類被繼承和方法被重寫。 1)標記類為final時,該類不能被繼承。 2)標記方法為final時,該方法不能被子類重寫。使用final關鍵字可以確保代碼的穩定性和安全性。

描述...(SPLAT)操作員在php函數參數和數組解開包裝中的目的和用法。 描述...(SPLAT)操作員在php函數參數和數組解開包裝中的目的和用法。 Apr 06, 2025 am 12:07 AM

PHP中的...(splat)操作符用於函數參數和數組解包,提升代碼簡潔性和效率。 1)函數參數解包:將數組元素作為參數傳遞給函數。 2)數組解包:將一個數組解包到另一個數組中或作為函數參數。

在PHP中解釋嚴格的類型(STRICT_TYPES = 1);)。 在PHP中解釋嚴格的類型(STRICT_TYPES = 1);)。 Apr 07, 2025 am 12:05 AM

PHP中的嚴格類型通過在文件頂部添加declare(strict_types=1);來啟用。 1)它強制對函數參數和返回值進行類型檢查,防止隱式類型轉換。 2)使用嚴格類型可以提高代碼的可靠性和可預測性,減少bug,提升可維護性和可讀性。

作曲家是用什麼? 作曲家是用什麼? Apr 06, 2025 am 12:02 AM

Composer是PHP的依賴管理工具。使用Composer的核心步驟包括:1)在composer.json中聲明依賴,如"stripe/stripe-php":"^7.0";2)運行composerinstall下載並配置依賴;3)通過composer.lock和autoload.php管理版本和自動加載。 Composer簡化了依賴管理,提升了項目效率和可維護性。

PHP的未來:改編和創新 PHP的未來:改編和創新 Apr 11, 2025 am 12:01 AM

PHP的未來將通過適應新技術趨勢和引入創新特性來實現:1)適應云計算、容器化和微服務架構,支持Docker和Kubernetes;2)引入JIT編譯器和枚舉類型,提升性能和數據處理效率;3)持續優化性能和推廣最佳實踐。

See all articles