monggodb学习过程--update
admin
2023-01-26 05:20:54
0

今天看书看到mongodb权威指南这本书对update这一篇进行了详细详解,因为知识点有点多,所以博客记录一下,如果只是看我觉得明天就忘了。

更新文档有两种方式:

1,文档替换  2,修改器替换(只是修改单个字段的内容)

关于update有哪些参数可以看一下帮助文档

db> db.blog.update
function (query, obj, upsert, multi)
query:条件
obj:对象,更新的类容
upsert:判断更新的条件是否存在
multi:默认情况下更新只对符合匹配条件的第一个文档执行操作,要是这个为true,就是配置内容所以都更新

文档替换

当前的数据类型是

wangaimin> db.test.findOne({"name":"bob"})
{
        "_id" : ObjectId("58e4b6410b8bd344936c8553"),
        "name" : "bob",
        "email" : "bob@email.com.cn",
        "content" : "nice post"
}

我需要变成这个样子:

wangaimin> db.test.find({"name" : "bob"})
{ "_id" : ObjectId("58e4b6410b8bd344936c8553"), 
"name" : "bob", 
"comments" : { "email" : "bob@email.com.cn", "content" : "nice post" } 
}

操作步骤是:

wangaimin> var Test=db.test.findOne({"name":"bob"})
Test.comments={"email":Test.email,"content":Test.content}
delete Test.content
delete Test.email
db.test.update({"name" : "bob"},Test)
其实这个地方有一个坑,就是_id,如果你匹配中有多个name="bob",你就会报错,_id必须是唯一的,所以可以也可以执行delete Test._id,这里没有写的很详细,大家可以仔细想一下,如果不想是没有记忆点

使用修改器:

1,$set修改器

修改之前:
wangaimin> db.test.find({"name" : "bob"})
{ "_id" : ObjectId("58e4b6410b8bd344936c8553"), "name" : "bob", "comments" : { "email" : "bob@email.com.cn", "content" : "nice post" } }

命令:db.test.update({"name" : "bob"},{$set:{"name":"BOB"}})
修改之后:
wangaimin> db.test.find({"name" : "BOB"})
{ "_id" : ObjectId("58e4b6410b8bd344936c8553"), "name" : "BOB", "comments" : { "email" : "bob@email.com.cn", "content" : "nice post" } }

修改内嵌文档:
命令:wangaimin> db.test.update({"name" : "BOB"},{$set:{"comments.content":"change le"}})
修改之后:
wangaimin> db.test.find({"name" : "BOB"})
{ "_id" : ObjectId("58e4b6410b8bd344936c8553"), "name" : "BOB", "comments" : { "email" : "bob@email.com.cn", "content" : "change le" } }
2,$inc 增加和减少
注意:$inc 键的值必须是数字,不能为字符串,数组或其他非数字的值
db.test.find()
{ "_id" : ObjectId("58e4bb4b0b8bd344936c8554"), "number" : 10 }
wangaimin> db.test.update({"number":10},{$inc:{"number":3}})
wangaimin> db.test.find()
{ "_id" : ObjectId("58e4bb4b0b8bd344936c8554"), "number" : 13 }

3,$push添加数组

如果数组已经存在,$push会向已有的数组末尾加入一个元素,要是没有就创建一个新的数组

 db.test.find()
{ "_id" : ObjectId("58e4bd5f0b8bd344936c8555"), "school" : "bd" }
db.test.update({"school":"bd"},{$push,{"list":{"name":"zhangsan","age":20}}})

db.test.find()
{ "_id" : ObjectId("58e4bd5f0b8bd344936c8555"), "school" : "bd", "list" : [ { "name" : "zhangsan", "age" : 20 } ] }

4,使用$each添加多个值

db.test.update({"school":"bd"},{$push:{"list":{$each:[{"name":"zhangsan","age":21},{"name":"zhangsan","age":22},{"name":"zhangsan","age":23},{"name":"zhangsan","age":24}]}}})

{ "_id" : ObjectId("58e4bd5f0b8bd344936c8555"), "school" : "bd", "list" : [ { "name" : "zhangsan", "age" : 20 }, { "name" : "zhangsan", "age" : 21 }, { "name" : "zhangsan", "age" : 22 }, { "name" : "zhangsan", "age" : 23 }, { "name" : "zhangsan", "age" : 24 } ] }

5,使用$slice限制个数,必须使用$each

使用$slice限制数组长度,如果$slice:-10,如果数组的长度小于10($push之后),那么所以的元素都会保留,如果数组的元素大于10,只有最后10个元素会报错,重点$slice的值必须是负数

wangaimin> db.test.find({"name":"test"})
{ "_id" : ObjectId("58e4c1d30b8bd344936c8556"), "name" : "test", "id" : [ 1, 2, 3, 4, 5, 7, 7, 1, 2, 3, 4, 5, 5 ] }
wangaimin> db.test.update({"name":"test"},{$push:{"id":{$each:[1,2,3],$slice:-5}}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
wangaimin> db.test.find({"name":"test"})
{ "_id" : ObjectId("58e4c1d30b8bd344936c8556"), "name" : "test", "id" : [ 5, 5, 1, 2, 3 ] }

6,将数组作为数据集使用($ne,$addToSet)

因为数组的元素是可以重复的,设置这个就是让数组的元素不可以重复



相关内容

热门资讯

德国总理:美国正在被伊朗羞辱 德国之声4月27日报道,德国总理默茨在访问一所学校时表示,在当前的持续冲突中,伊朗领导层正试图羞辱美...
理响中国|“长”歌以行,风云激... 光阴如梭,东方潮阔。这里是中国的长三角,世界的长三角。无论过去、现在还是未来,这片土地都因时代而生,...
白宫:特朗普及其国安团队开会讨... 新华社华盛顿4月27日电 美国白宫新闻秘书莱维特27日在记者会上证实,总统特朗普及其国家安全团队当天...
人民日报刊文:日本放开杀伤性武... 日本放开杀伤性武器出口推高地缘冲突风险(国际论坛)常思纯《人民日报》(2026年04月28日 第 0...
医疗保障法草案二审:明确生育保... 满足多样化健康保障需求本报记者 彭 波4月27日,医疗保障法草案二审稿提请十四届全国人大常委会第二十...
天津一景区发生自转旋翼机事故1... 澎湃新闻记者 吕新文中国民用航空华北地区管理局4月22日公布《豪客通航“10•1”天津长芦汉盐旅游区...
卡塔尔埃米尔与美国总统特朗普通... 当地时间24日,卡塔尔埃米尔塔米姆与美国总统特朗普通电话,重点就中东地区局势以及伊朗与美国谈判问题交...
男子30年前被扣押2859克黄... 澎湃新闻记者 王鑫家住辽宁省大连市的潘永嘉近日向澎湃新闻反映称,三十年前,他在大连周水子机场被盖州市...
商务部:取消反制欧盟两家金融机... 中华人民共和国商务部令二〇二六年 第1号鉴于欧盟已取消对中国两家金融机构的制裁措施,现公布《关于取消...
过去24小时共有5艘船只通过霍... 总台记者当地时间24日获悉,过去24小时内,共有5艘船只通过霍尔木兹海峡,其中包括一艘伊朗油轮。(总...