MongoDB入门3——更新文档和修改器1
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,我们前面讲MongoDB的CRUD操作讲过:MongoDB的更新操作通过集合的update()函数实现。这个函数有两个参数:要更改的文档和更改后的样子。要更新文档有两种情况:更新文档和对文档某些部分更
千家信息网最后更新 2025年11月08日MongoDB入门3——更新文档和修改器1
我们前面讲MongoDB的CRUD操作讲过:MongoDB的更新操作通过集合的update()函数实现。这个函数有两个参数:要更改的文档和更改后的样子。要更新文档有两种情况:更新文档和对文档某些部分更新。下面分别说说这两种情况:
1.更新整个文档
假设现在有下面的一个文档:
- {"name":"zhangsan","dad":"zhangyi","mom":"lisi"};
如果觉得这样不好,需要讲父亲和母亲的信息组织到一起,成为一个新的文档:parents,另外,加上一个年龄字段age.那么新的文档如下:
- {"name":"zhangsan","age":20,"parents":{dad:"zhangyi","mom":"lisi"}};
如果要将数据库中的第一个文档替代为上面第二个文档,使用update操作的过程如下:
- > var zhangsan = db.info.findOne({"name" : "zhangsan"});
- > zhangsan
- {
- "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"),
- "name" : "zhangsan",
- "dad" : "zhangyi",
- "mom" : "lisi"
- }
- > zhangsan.parents={"dad":zhangsan.dad,"mom":zhangsan.mom};
- { "dad" : "zhangyi", "mom" : "lisi" }
- > zhangsan
- {
- "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"),
- "name" : "zhangsan",
- "dad" : "zhangyi",
- "mom" : "lisi",
- "parents" : {
- "dad" : "zhangyi",
- "mom" : "lisi"
- }
- }
- > zhangsan.age=20
- 20
- > zhangsan
- {
- "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"),
- "name" : "zhangsan",
- "dad" : "zhangyi",
- "mom" : "lisi",
- "parents" : {
- "dad" : "zhangyi",
- "mom" : "lisi"
- },
- "age" : 20
- }
- > delete zhangsan.dad
- true
- > zhangsan
- {
- "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"),
- "name" : "zhangsan",
- "mom" : "lisi",
- "parents" : {
- "dad" : "zhangyi",
- "mom" : "lisi"
- },
- "age" : 20
- }
- > delete zhangsan.mom
- true
- > zhangsan
- {
- "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"),
- "name" : "zhangsan",
- "parents" : {
- "dad" : "zhangyi",
- "mom" : "lisi"
- },
- "age" : 20
- }
- > db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},zhangsan);
- > db.info.find();
- { "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" }, "age" : 20 }
- >
以这种方式进行文档更新需要注意一点:尽量通过_id来匹配需要被替换的文档。至于为什么,我想用过数据库的人应该都能明白(类似于用主键去匹配特性的记录)。
2.使用修改器部分修改文档的一部分
a) $set修改器
$set修改器指定一个键的新值,若不存在则创建新的。我们要给上面的zhangsan文档(数据库中的)添加一个wife键值对。
- > db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},{"$set":{"wife":"wangwu"}});
- > db.info.find();
- { "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "age" : 20, "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" }, "wife" : "wangwu" }
- >
现在过了一年,张三已经是21岁了,那么可以使用$set更新age键的值:
- > db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},{"$set":{"age":21}});
- > db.info.find();
- { "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "age" : 21, "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" }, "wife" : "wangwu" }
- >
当然这种情况还有别的修改器可以实现,并且更合适,我们一会会继续介绍。
zhangsan离婚了,没老婆了,怎们办?我们可以通过$unset修改器来撤销wife这个键值对。(PS:这个例子不是很合适,太残酷了)
- > db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},{"$unset":{"wife":1}});
- > db.info.find();
- { "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "age" : 21, "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" } }
- >
b)$inc修改器
$inc修改器增加和修改已有键的值(只适用于数字类型)。上面我们提到,随着时间推移,zhangsan的年龄会不断增大,就可以使用这个修改器:
- > db.info.update({"_id" : ObjectId("4ee37409c3fc1a9f80ad74ed")},{"$inc":{"age":1}});
- > db.info.find();
- { "_id" : ObjectId("4ee37409c3fc1a9f80ad74ed"), "age" : 22, "name" : "zhangsan", "parents" : { "dad" : "zhangyi", "mom" : "lisi" } }
- >
这个修改器非常适合那些投票、计分、访问量统计一类的情况。但是得注意,这个选择器只适用于对数字类型的键值对进行增加和减少。减少只需要传递负值就可以了。
文档
修改器
更新
情况
数据
数据库
合适
函数
年龄
数字
类型
部分
面的
残酷
不好
不断
两个
例子
信息
参数
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
服务器硬盘格式化卡死怎么办
棋牌游戏软件开发与定制
施乐1450服务器中文版
四川项目软件开发价位
盐城智能软件开发流程
软件开发互助盘
计算机服务器发热功率
手机同名数据库在哪找
网络安全宣传绘画手抄报图片
软件开发流程他
服务器安全狗强度
美赛查重数据库
制作网站和软件开发哪个好
青少年网络安全小报
电脑nds服务器不可用
大手牵小手网络安全主题绘画
登陆rtx服务器
清空一个表的数据库
hp服务器引导光盘
赵瑞琦 美国网络安全
洞悉网络技术视频
信息软件开发公司聚顶科技
iphone6激活服务器
我的世界暮云服务器
藤校之夜互联网科技下
运维管理系统开发软件开发
怎么登陆服务器mc
餐饮软件开发咨询客服
更改泰拉瑞亚的服务器端口
泉州市网络技术大赛