MongoDB入门3——更新文档和修改器1
发表于:2025-02-04 作者:千家信息网编辑
千家信息网最后更新 2025年02月04日,我们前面讲MongoDB的CRUD操作讲过:MongoDB的更新操作通过集合的update()函数实现。这个函数有两个参数:要更改的文档和更改后的样子。要更新文档有两种情况:更新文档和对文档某些部分更
千家信息网最后更新 2025年02月04日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安全错误
数据库的锁怎样保障安全
服务器系统一拖二
深圳3u服务器散热器厂家
数据库什么是角色
软件开发系统框架设计
数据库表字段怎么写
sdy网络技术
金蝶专业版数据库删除辅助属性
数据库用户名不存在怎么办
网站网络安全方法
建立空间数据库的目的
膳食数据库具有的特点
京东方光电科技工业互联网
河北软件开发平台
构建网络安全手抄报
软件开发定制商城app 小程序
网络安全的选题意义
中草药图像数据库
sql数据库转换成中文版
联通网络安全人才
网络安全专题会议简报
无锡塔式服务器
vue 连接数据库
恩施放心的软件开发公司
方舟服务器如何改成pve
黎明职业大学计算机网络技术
intel软件开发工具
网络安全工作服
绝地服务器选择
今年网络安全开了哪些会议
b站网络技术大神