下面常用的update操作,用mongodb2.6.3版本测试的,官方发布的稳定版本2.4,建议用稳定版。 一,upsert表示如果有数据就不插入,没数据就插入 1,命令行下 db.peoples.update( //查找name等于tank的用户... { name: "tank" },... {... "_id":1,... name: "An
下面常用的update操作,用mongodb2.6.3版本测试的,官方发布的稳定版本2.4,建议用稳定版。
一,upsert表示如果有数据就不插入,没数据就插入
1,命令行下
> db.peoples.update( //查找name等于tank的用户 ... { name: "tank" }, ... { ... "_id":1, ... name: "Andy", ... rating: 10, ... score: 10 ... }, ... { upsert: true } //如果没有就插入 ... ); WriteResult({ "nMatched" : 0, "nUpserted" : 1, "_id" : 1 }) > db.peoples.find(); { "_id" : 1, "name" : "Andy", "rating" : 10, "score" : 10 } > db.peoples.update( ... { _id: 1 }, ... { ... "_id":1, ... name: "Andy", ... rating: 10, ... score: 10 ... }, ... { upsert: true } ... ); WriteResult({ "nMatched" : 1, "nUpserted" : 0 }) //有匹配数据就不做插入操作 > db.peoples.find(); { "_id" : 1, "name" : "Andy", "rating" : 10, "score" : 10 }
2,php upsert操作
$collection->update( array("name" => "zhang"), array("_id"=>2,"name"=>"tank","rating"=>10,"score"=>10), array("upsert" => true) ); print_r($collection->findOne());
二,$set 替换值
1,命令行下操作
> db.peoples.find(); { "_id" : 1, "name" : "Andy", "rating" : 10, "score" : 10 } > db.peoples.update( ... { _id: 1 }, ... { ... $set: { rating: 18 } ... } ... ); WriteResult({ "nMatched" : 1, "nUpserted" : 0 }) > db.peoples.find(); { "_id" : 1, "name" : "Andy", "rating" : 18, "score" : 10 }
2,php $set操作
$where = array("_id"=>1); $param = array('$set'=>array("score"=>"100")); //注意此处的set必须为 单引号 $collection->update($where,$param); print_r($collection->findOne());
三,$inc如果没有对应对段就直接赋值,如果有在原来的值上加上该值
1,命令行下操作
> db.peoples.find(); { "_id" : 1, "name" : "Andy", "rating" : 28, "score" : 10 } > db.peoples.update( ... { _id: 1 }, ... { ... $inc: { age: 30 } ... } ... ); WriteResult({ "nMatched" : 1, "nUpserted" : 0 }) > db.peoples.find(); { "_id" : 1, "age" : 30, "name" : "Andy", "rating" : 28, "score" : 10 } //第一次,加了一个字段 > db.peoples.update( ... { _id: 1 }, ... { ... $inc: { age: 30 } ... } ... ); WriteResult({ "nMatched" : 1, "nUpserted" : 0 }) > db.peoples.find(); { "_id" : 1, "age" : 60, "name" : "Andy", "rating" : 28, "score" : 10 } //第二次,发现有这个字段就把值加上去了
2,php $inc操作
$where = array("_id"=>1); $param = array('$inc'=>array("age"=>30)); $collection->update($where,$param); print_r($collection->findOne());
四,$unset删除字段
1,命令行下操作
> db.peoples.find(); { "_id" : 1, "age" : 120, "name" : "Andy", "rating" : 28, "score" : 10 } > db.peoples.update( ... { _id: 1 }, ... { ... $unset: { age: ""} //删除age字段 ... } ... ); WriteResult({ "nMatched" : 1, "nUpserted" : 0 }) > db.peoples.find(); { "_id" : 1, "name" : "Andy", "rating" : 28, "score" : 10 } >
2,php $unset操作
$where = array("_id"=>1); $param = array('$unset'=>array("score"=>"")); $collection->update($where,$param); print_r($collection->findOne());
五,$rename修改字段名称
1,命令行下操作
> db.peoples.find(); { "_id" : 1, "name" : "Andy", "rating" : 28 } > db.peoples.update( ... { _id: 1 }, ... { $rename: { "name": "firstname" } } //将name改成firstname ... ); WriteResult({ "nMatched" : 1, "nUpserted" : 0 }) > db.peoples.find(); { "_id" : 1, "firstname" : "Andy", "rating" : 28 }
2,php $rename 操作
$where = array("_id"=>1); $param = array('$rename'=>array("firstname"=>"name")); //将firstname改成name $collection->update($where,$param); print_r($collection->findOne());
六,multi更新多条数据
1,命令行下操作
> db.peoples.find(); { "_id" : 1, "name" : "Andy", "rating" : 28 } { "_id" : 2, "name" : "zhang", "rating" : 3, "score" : 5 } { "_id" : 3, "name" : "hao", "rating" : 30, "score" : 5 } > db.peoples.update( ... { rating: { $gt: 15 } }, ... { $inc: { score: 10 } }, ... { multi: true } ... ); WriteResult({ "nMatched" : 2, "nUpserted" : 0 }) > db.peoples.find(); { "_id" : 1, "name" : "Andy", "rating" : 28, "score" : 10 } //这条数据更新了 { "_id" : 2, "name" : "zhang", "rating" : 3, "score" : 5 } { "_id" : 3, "name" : "hao", "rating" : 30, "score" : 15 } //这条数据更新了
2,php multi操作
$where = array("rating"=>array('$gt'=>10)); $param = array('$set'=>array("name"=>"tank1","rating"=>50)); $ismore = array("multiple" => true); $collection->update($where,$param,$ismore);
版本不一样,功能多少会不一样,例如,我用的版本是2.6.3,$min和$max就用不了,会报"errmsg" : "Invalid modifier specified $min",希望mongodb出一个稳定高版本。
原文地址:mongodb update 字符 操作, 感谢原作者分享。

mongodb php扩展没有的解决办法:1、在linux中执行“$ sudo pecl install mongo”命令来安装MongoDB的PHP扩展驱动;2、在window中,下载php mongodb驱动二进制包,然后在“php.ini”文件中配置“extension=php_mongo.dll”即可。

Redis和MongoDB都是流行的开源NoSQL数据库,但它们的设计理念和使用场景有所不同。本文将重点介绍Redis和MongoDB的区别和使用场景。Redis和MongoDB简介Redis是一个高性能的数据存储系统,常被用作缓存和消息中间件。Redis以内存为主要存储介质,但它也支持将数据持久化到磁盘上。Redis是一款键值数据库,它支持多种数据结构(例

MongoDB是一种高性能、开源、文档型的NoSQL数据库,被广泛应用于Web应用、大数据以及云计算领域。而Go语言则是一种快速、开发效率高、代码可维护性强的编程语言。本文将为您完整介绍如何在Go语言中使用MongoDB。一、安装MongoDB在使用MongoDB之前,需要先在您的系统中安装MongoDB。在Linux系统下,可以通过如下命令安装:sudo

php7.0安装mongo扩展的方法:1、创建mongodb用户组和用户;2、下载mongodb源码包,并将源码包放到“/usr/local/src/”目录下;3、进入“src/”目录;4、解压源码包;5、创建mongodb文件目录;6、将文件复制到“mongodb/”目录;7、创建mongodb配置文件并修改配置即可。

MongoDB作为一款流行的NoSQL数据库,已经被广泛应用于各种大型Web应用和企业级应用中。而PHP语言也作为一种流行的Web编程语言,与MongoDB的结合也变得越来越重要。在本文中,我们将会学习如何使用PHP语言操作MongoDB数据库进行增删查改的操作。

自定义Appender非常简单,继承一下AppenderBase类即可。可以看到有个AppenderBase,有个UnsynchronizedAppenderBase,还有个AsyncAppenderBase继承了UnsynchronizedAppenderBase。从名字就能看出来区别,异步的、普通的、不加锁的。我们定义一个MongoDBAppender继承UnsynchronizedAppenderBasepublicclassMongoDBAppenderextendsUnsynchron

一、什么是MongoDBMongoDB与我们之前熟知的关系型数据库(MySQL、Oracle)不同,MongoDB是一个文档数据库,它具有所需的可伸缩性和灵活性,以及所需的查询和索引。MongoDB将数据存储在灵活的、类似JSON的文档中,这意味着文档的字段可能因文档而异,数据结构也会随着时间的推移而改变。文档模型映射到应用程序代码中的对象,使数据易于处理。MongoDB是一个以分布式数据库为核心的数据库,因此高可用性、横向扩展和地理分布是内置的,并且易于使用。况且,MongoDB是免费的,开源

在现代企业应用程序开发中,需要处理海量数据和高并发的访问请求。为了满足这些需求,开发人员需要使用高性能的数据库系统,以确保系统的稳定性和可扩展性。本文将介绍如何使用Swoole和MongoDB构建高性能的文档数据库系统。Swoole是一个基于PHP语言开发的异步网络通信框架,它能够大大提高PHP应用程序的性能和并发能力。MongoDB是一种流行的文档数据库,


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

SublimeText3汉化版
中文版,非常好用

Dreamweaver CS6
视觉化网页开发工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中