鱼C论坛

 找回密码
 立即注册

mongodb数据更新操作

已有 583 次阅读2017-9-25 22:34 |个人分类:MongoDB学习笔记

1.1.1数据更新操作
对于MongoDB而言,数据的更新基本上是一件很麻烦的事。如果在实际的工作之中,真的具有此类的操作支持,那么最好的做法,在MongoDB里面对于数据的更新操作提供了两类函数save(),updata()
1.1.1.1函数的基本使用
如果要修改数据,最直接的使用函数就是update()函数,但是这个函数的语法要求很麻烦
语法:db.集合.update(更新条件,新的对象数据(更新操作符),upsert,multi)
upsert:如果要更新的数据不存在,则增加一条新的内容(true为增加,false为不增加)
multi  :表示是否只更新满足条件的第一行记录,如果设置为false,只更新第一条,如果是true则全更新
范例:将年龄是19岁的人的成绩都更新为100分
更新一条数据
范例:更新不存在的数据

由于没有年龄是30岁的学生信息,所以此时相当于进行了数据的创建。

那么除了updata()函数之外,还提供了一个sava()函数,这个函数的功能与更新不存在的内容相似

范例:使用save操作

由于此时对应的id数据存在了,所以就变成了更新操作,但是如果要保存的数据不存在(不能有id),就变为了增加操作

尽量不用save,用updata。


1.1.1.1修改器

对MongoDB数据库而言,数据的修改会牵扯到内容的变更,结构的变更(包含有数组),所以在进行MongoDB设计的时候,就提供有一系列修改器的应用。那么像之前使用的"$set"就是一个修改器。

1. $inc:主要针对于一个数字字段,增加某个数字字段的数据内容。

语法:{"$inc":{成员:内容}}

范例:将所有年龄为19岁的学生成绩一律减少30分


2. $set :进行内容的重新设置
语法:{"$set":{"成员","新内容"}}
范例:将年龄是20岁的人的成绩修改为89

3. $unset :删除某个成员的内容

语法:{"$unset":{"成员":1}}

范例:删除"张三"的年龄与成绩信息

执行之后指定的成员内容就消失了

4. $push :相当于将内容追加到指定的成员之中(基本上是数组):

范例:向"张三"添加课程信息(此时张三信息下没有course)



路过

雷人

握手

鲜花

鸡蛋

评论 (0 个评论)

facelist

您需要登录后才可以评论 登录 | 立即注册

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-3-18 22:46

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

返回顶部