搜尋
首頁後端開發PHP問題php mongodb如何實現增刪改查

php mongodb如何實現增刪改查

Mar 08, 2021 am 11:33 AM
mongodbphp增刪改查

php mongodb實作增刪改查的方法:1、資料插入,程式碼為【$res = $collection->insert($doc)】;2、資料查詢,程式碼為【$one = $ collection->findOne(['First Name)】。

php mongodb如何實現增刪改查

本教學操作環境:windows7系統、PHP5.6版,DELL G3電腦。

php mongodb實作增刪改查的方法:

MongoDB的PHP驅動程式提供了一些核心類別來操作MongoDB,總的來說MongoDB命令列中有的功能,它都可以實現,而且參數的格式基本上相似。 PHP7先前的版本和PHP7之後的版本對MongoDB的操作有所不同,本文主要以PHP7以前版本為例講解PHP對MongoDB的各種操作,最後再簡單說明一下PHP7以後版本對MongoDB的操作。

一、資料插入

//insert()
//参数1:一个数组或对象
//参数2:扩展选项
//  fsync:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入硬盘
//  j:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入日志
//  w:默认为1,写操作会被(主)服务器确认,若为0则将不会得到确认,使用复制集时设置为n用于确保主服务器将数据修改成功复制到n个节点后再确认
//  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
//  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)
$mongo = new MongoClient('mongodb://localhost:27017');
$db = $mongo->mf;//选择数据库
$collection = $db->friend;//选择文档集合
$doc = [//定义一个文档,即一个数组
    'First Name' => 'Jet',
    'Last Name' => 'Wu',
    'Age' => 26,
    'Phone' => '110',
    'Address' => [
        'Country' => 'China',
        'City' => 'Shen Zhen'
    ],
    'E-Mail' => [
        '123456@qq.com',
        '666666@sina.com',
        '8888888@qq.com',
        '77887788@qq.com'
    ]
];
$res = $collection->insert($doc);//向集合中插入一个文档
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($res);//$res[&#39;ok&#39;]=1表示插入成功

二、資料查詢

1.查詢單一文件:

//findOne()
//参数1:搜索条件
//参数2:指定返回字段,array(&#39;fieldname&#39; => true, &#39;fieldname2&#39; => true)。_id字段总会返回,除非在第二个参数显式加入&#39;_id&#39;=>false。不设置则返回所有字段
$mongo = new MongoClient(&#39;mongodb://localhost:27017&#39;);
$db = $mongo->mf;
$collection = $db->friend;
$one = $collection->findOne([&#39;First Name&#39; => &#39;Jet&#39;]);
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($one);//返回一个数组,查不到数据则返回NULL

2. 查詢多個文件:

//find()
//参数1:搜索条件
//参数2:指定返回字段,array(&#39;fieldname&#39; => true, &#39;fieldname2&#39; => true)。_id字段总会返回,除非显式设置为false不返回。不设置则返回所有字段
$mongo = new MongoClient(&#39;mongodb://localhost:27017&#39;);
$db = $mongo->mf;
$collection = $db->friend;
$cursor = $collection->find([&#39;Address.Country&#39; => &#39;China&#39;]);//使用点操作符查找数组元素
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
while($doc = $cursor->getNext()) {//循环读取每个匹配的文档
    print_r($doc);
}

使用各種條件運算子定義查詢:

//mongodb分别使用$lt、$lte、$eq、$gte、$gt、$ne表示<、<=、=、>=、>、<>,用于整数字段查询
$mongo = new MongoClient(&#39;mongodb://localhost:27017&#39;);
$db = $mongo->mf;
$collection = $db->friend;
$cursor = $collection->find([&#39;Age&#39; => [&#39;$gt&#39; => 30]]);
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
while($doc = $cursor->getNext()) {
    print_r($doc);
}
  //查询某个字段的所有不重复的值
  $res = $collection->distinct(&#39;Age&#39;);
//$in:匹配多个值中任意一个
$cursor = $collection->find([&#39;Address.Country&#39; => [&#39;$in&#39; => [&#39;China&#39;, &#39;USA&#39;]]]);
 
//$all:匹配多个值中所有值(用于数组字段查询)
$cursor = $collection->find([&#39;E-Mail&#39; => [&#39;$all&#39; => [&#39;123456@qq.com&#39;, &#39;77887788@qq.com&#39;]]]);
 
//$or:或查询
$cursor = $collection->find([&#39;$or&#39; => [[&#39;First Name&#39; => &#39;Jet&#39;], [&#39;Address.Country&#39; => &#39;USA&#39;]]]);
 
//$slice:获取数组字段中指定数目的元素,位于find()函数第二个参数中
$cursor = $collection->find([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;E-Mail&#39; => [&#39;$slice&#39; => 2]]);//只返回前两个email
$cursor = $collection->find([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;E-Mail&#39; => [&#39;$slice&#39; => -2]]);//只返回最后两个email
$cursor = $collection->find([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;E-Mail&#39; => [&#39;$slice&#39; => [1, 2]]]);//忽略第一个,返回接下来两个
 
//$exists:根据某个字段是否有设置值进行查询
$cursor = $collection->find([&#39;Hobby&#39; => [&#39;$exists&#39; => false]]);//查找Hobby字段未设置值的文档
 
//正则表达式查询
$cursor = $collection->find([&#39;First Name&#39; => new MongoRegex(&#39;/^Je/i&#39;)]);//查找First Name字段以Je开头的文档,忽略大小写差异

使用MongoCursor類別提供的其他函數:

//排序:1升序,-1降序
$cursor->sort([&#39;Age&#39; => 1]);
 
//忽略前n个匹配的文档
$cursor->skip(1);
 
//只返回前n个匹配的文档(limit()与skip()结合使用可实现数据分页功能)
$cursor->limit(1);
 
//匹配文档的总数
$cursor->count();
 
//指定查询索引
$cursor->hint([&#39;Last Name&#39; => -1]);//若索引不存在则会报错

#會聚集查詢:將資料分組統計

//聚合查询:对数据进行分组统计
$mongo = new MongoClient(&#39;mongodb://localhost:27017&#39;);
$db = $mongo->mf;
$collection = $db->friend;
$res = $collection->aggregate([
    &#39;$group&#39; => [
        &#39;_id&#39; => &#39;$Address.Country&#39;,//分组字段,注意要加上“$”,这里是根据数组字段某个元素值进行分组
        &#39;total&#39; => [&#39;$sum&#39; => 1],//求总和,表示每匹配一个文档总和就加1
        &#39;maxAge&#39; => [&#39;$max&#39; => &#39;$Age&#39;],//分组中Age字段最大值
        &#39;minAge&#39; => [&#39;$min&#39; => &#39;$Age&#39;]//分组中Age字段最小值
    ]
]);
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($res);//返回一个数组,$ret[&#39;result&#39;]为数组,存放统计结果
 
 
//存在其它操作的聚合查询:多个操作之间执行先后顺序取决于它们位置的先后顺序
//聚合查询中的所有操作,包括&#39;$group&#39;在内,都是可选的。
$mongo = new MongoClient(&#39;mongodb://localhost:27017&#39;);
$db = $mongo->mf;
$collection = $db->friend;
$res = $collection->aggregate([
    [//过滤条件:只对符合条件的原始文档进行聚合运算,若是放在&#39;$group&#39;之后则是只返回符合条件的结果文档
        &#39;$match&#39; => [&#39;Age&#39; => [&#39;$gt&#39; => 30]]
    ],
    [//指定分组字段、统计字段
        &#39;$group&#39; => [
            &#39;_id&#39; => &#39;$Address.Country&#39;,
            &#39;totalAge&#39; => [&#39;$sum&#39; => &#39;$Age&#39;]//计算各个分组Age字段总和
        ]
    ],
    //以下操作若是放在&#39;$group&#39;之前则在聚合前作用于原始文档,若放在&#39;$group&#39;之后则在聚合后作用于结果文档
    [&#39;$unwind&#39; => &#39;$E-Mail&#39;],//将包含有某个数组类型字段的文档拆分成多个文档,每个文档的同名字段的值为数组中的一个值。
    [&#39;$project&#39; => [&#39;myAge&#39; => &#39;$Age&#39;, &#39;First Name&#39; => &#39;$First Name&#39;]],//指定返回字段,可以对字段进行重命名,格式:返回字段名 => $原来字段名
    [&#39;$skip&#39; => 2],//跳过指定数量的文档
    [&#39;$limit&#39; => 2],//只返回指定数量的文档
    [&#39;$sort&#39; => [&#39;totalAge&#39; => 1]]//排序
]);
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($res);

三、資料修正

//update()
//参数1:更新条件,指定更新的目标对象。
//参数2:指定用于更新匹配记录的对象。
//参数3:扩展选项组。
//  upsert:若设置为true,当没有匹配文档的时候会创建一个新的文档。
//  multiple:默认为false,若设置为true,匹配文档将全部被更新。
//  fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。
//  w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作
//  j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。
//  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
//  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)
//注意:若不使用任何修改操作符,则匹配文档将直接被整个替换为参数2指定的对象。
 
//$inc:增加特定键的值,若字段不存在则新建字段并赋值
$mongo = new MongoClient(&#39;mongodb://localhost:27017&#39;);
$db = $mongo->mf;
$collection = $db->friend;
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$inc&#39; => [&#39;Age&#39; => 2]]);
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($res);//$res[&#39;ok&#39;]=1表示修改成功,$res[&#39;nModified&#39;]表示修改的文档数量
 
//$set:重置特定键的值,若字段不存在则新建字段并赋值
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$set&#39; => [&#39;Hobby&#39; => &#39;pingpong&#39;]]);
 
//$unset:删除字段
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$unset&#39; => [&#39;Hobby&#39; => 1]]);
 
//$rename:重命名字段,若字段不存在则不进行任何操作
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$rename&#39; => [&#39;Hobby&#39; => &#39;hobby&#39;, &#39;Age&#39; => &#39;age&#39;]]);
//注意:如果文档中已经使用了指定名称的字段,则该字段将会被删除,然后再进行重命名操作。
 
//$setOnInsert:设置了upsert为true,并且发生了插入操作的时候,将某个字段设置为特定的
$res = $collection->update([&#39;First Name&#39; => &#39;jet&#39;], [&#39;$setOnInsert&#39; => [&#39;lang&#39; => &#39;English&#39;]], [&#39;upsert&#39; => true]);
 
//$push:向指定字段添加一个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$push&#39; => [&#39;E-Mail&#39; => &#39;123123@qq.com&#39;]]);
 
//$push:向指定字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$pushAll&#39; => [&#39;E-Mail&#39; => [&#39;666@qq.com&#39;, &#39;8888888@qq.com&#39;]]]);
 
//使用$push和$each向某个字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$push&#39; => [&#39;E-Mail&#39; => [&#39;$each&#39; => [&#39;123123@qq.com&#39;, &#39;666@qq.com&#39;]]]]);
 
//$addToSet:将数据添加到数组中(只在目标数组没有该数据的时候才将数据添加到数组中)
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$addToSet&#39; => [&#39;E-Mail&#39; => &#39;123123@qq.com&#39;]]);
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$addToSet&#39; => [&#39;E-Mail&#39; => [&#39;$each&#39; => [&#39;123123@qq.com&#39;, &#39;666@qq.com&#39;]]]]);
 
//$pop:从数组中删除一个元素,-1表示删除第一个元素,1表示删除最后一个元素(其实负数都删除第一个元素,0或正数都删除最后一个元素)
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$pop&#39; => [&#39;E-Mail&#39; => 1]]);
 
//$pull:删除数组中所有指定值
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$pull&#39; => [&#39;E-Mail&#39; => &#39;123123@qq.com&#39;]]);
 
//$pullAll:删除数组中多个元素的所有值
$res = $collection->update([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$pullAll&#39; => [&#39;E-Mail&#39; => [&#39;123123@qq.com&#39;, &#39;666@qq.com&#39;]]]);
//save()
//参数1:希望保存的信息数组
//参数2:扩展选项
//  fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。
//  w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作
//  j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。
//  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
//  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)
//注意:若已存在则更新,若不存在则插入;更新时使用参数1指定的信息数组替换整个文档。
//若想更新则应该在参数1中指定_id键的值。
$mongo = new MongoClient(&#39;mongodb://localhost:27017&#39;);
$db = $mongo->mf;
$collection = $db->friend;
$doc = [//定义一个文档,即一个数组
    &#39;First Name&#39; => &#39;Jet&#39;,
    &#39;Last Name&#39; => &#39;Wu&#39;,
    &#39;Age&#39; => 26,
    &#39;Phone&#39; => &#39;110&#39;,
    &#39;Address&#39; => [
        &#39;Country&#39; => &#39;China&#39;,
        &#39;City&#39; => &#39;Shen Zhen&#39;
    ],
    &#39;E-Mail&#39; => [
        &#39;123456@qq.com&#39;,
        &#39;666666@sina.com&#39;,
        &#39;8888888@qq.com&#39;,
        &#39;77887788@qq.com&#39;
    ]
];
$res = $collection->save($doc);
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($res);//$res[&#39;ok&#39;]=1表示操作成功,$res[&#39;updatedExisting&#39;]=1表示更新,$res[&#39;upserted&#39;]=1表示插入
//findAndModify()
//参数1:指定查询条件
//参数2:指定用于更新文档的信息
//参数3:可选,指定希望返回的字段
//参数4:扩展选项
//  sort:以特定顺序对匹配文档进行排序
//  remove:若设置为true,第一个匹配文档将被删除
//  update:若设置为true,将在被选择的文档上执行更新操作
//  new:默认为false,若设置为true则返回更新后的文档,否则返回更新前的文档
//  upsert:若设置为true,没有找到匹配文档的时候将插入一个新的文档
$mongo = new MongoClient(&#39;mongodb://localhost:27017&#39;);
$db = $mongo->mf;
$collection = $db->friend;
$res = $collection->findAndModify([&#39;First Name&#39; => &#39;Jet&#39;], [&#39;$push&#39; => [&#39;E-Mail&#39; => &#39;111@qq.com&#39;]]);
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($res);

#四、資料刪除

//remove()
//参数1:查询条件
//参数2:扩展选项
//  justOne:若设置为true,则最多只有一个匹配的文档将被删除
//  fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。
//  w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作
//  j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。
//  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
//  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)
$mongo = new MongoClient(&#39;mongodb://localhost:27017&#39;);
$db = $mongo->mf;
$collection = $db->friend;
$res = $collection->remove([&#39;First Name&#39; => &#39;jet&#39;]);
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($res);//$res[&#39;n&#39;]表示删除了几个文档

#相關影片推薦:PHP影片教學

#

以上是php mongodb如何實現增刪改查的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡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脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器