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 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

一致式(PHP 8)とそれがスイッチとどのように異なるかを説明します。 一致式(PHP 8)とそれがスイッチとどのように異なるかを説明します。 Apr 06, 2025 am 12:03 AM

PHP8では、一致式は、式の値に基づいて異なる結果を返す新しい制御構造です。 1)Switchステートメントに似ていますが、実行ステートメントブロックの代わりに値を返します。 2)一致式の式は厳密に比較され、セキュリティが向上します。 3)スイッチステートメントの脱落の可能性を回避し、コードのシンプルさと読みやすさを向上させます。

クロスサイトリクエストフォーファリー(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では、最終的なキーワードを使用して、クラスが継承されないようにし、メソッドが上書きされます。 1)クラスを決勝としてマークする場合、クラスを継承することはできません。 2)メソッドを最終的にマークする場合、メソッドはサブクラスによって書き換えられません。最終的なキーワードを使用すると、コードの安定性とセキュリティが保証されます。

PHP関数引数と配列の開梱で...(SPLAT)演算子の目的と使用について説明してください。 PHP関数引数と配列の開梱で...(SPLAT)演算子の目的と使用について説明してください。 Apr 06, 2025 am 12:07 AM

PHPの...(SPLAT)演算子は、機能パラメーターと配列を開梱するために使用され、コードのシンプルさと効率を向上させます。 1)関数パラメーター解放:アレイ要素をパラメーターとして関数に渡します。 2)配列の開梱:アレイを別の配列または関数パラメーターに解除します。

PHPで厳密なタイプ(declare(strict_types = 1);)を説明します。 PHPで厳密なタイプ(declare(strict_types = 1);)を説明します。 Apr 07, 2025 am 12:05 AM

PHPの厳格なタイプは、declare(strict_types = 1)を追加することで有効になります。ファイルの上部に。 1)関数パラメーターのタイプチェックと戻り値を強制して、暗黙の型変換を防ぎます。 2)厳格なタイプを使用すると、コードの信頼性と予測可能性を改善し、バグを減らし、保守性と読みやすさを向上させることができます。

作曲家は何に使用されていますか? 作曲家は何に使用されていますか? Apr 06, 2025 am 12:02 AM

作曲家は、PHPの依存関係管理ツールです。 Composerを使用するコアステップは次のとおりです。1)「Stripe/Stripe-PHP」などのComposer.jsonの依存関係を宣言:「^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