MongoDB 更新文档

一 简介
MongoDB 使用 update() 和 save() 方法来更新集合中的文档。
 
二 update() 方法
1、update() 方法用于更新已存在的文档。语法格式如下:
db.collection.update(
   <query>,
   <update>,
   {
     upsert: <boolean>,
     multi: <boolean>,
     writeConcern: <document>
   }
)
参数说明:
query : update的查询条件,类似sql update查询内where后面的。
update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的部分
upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
writeConcern :可选,抛出异常的级别。
2、实例
我们在集合 col 中插入如下数据:
  1. > db.col.insert(document)
  2. WriteResult({ "nInserted" : 1 })
  3. > db.col.insert({
  4. ... title: 'MongoDB 教程',
  5. ... description: 'MongoDB 是一个 Nosql 数据库',
  6. ... by: '菜鸟教程',
  7. ... url: 'http://www.runoob.com',
  8. ... tags: ['mongodb', 'database', 'NoSQL'],
  9. ... likes: 100
  10. ... })
  11. WriteResult({ "nInserted" : 1 })
接着通过 update() 方法来更新标题(title):
  1. > db.col.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}})
  2. WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
  3. > db.col.find().pretty()
  4. {
  5. "_id" : ObjectId("593b6160bcd6757fd2d302fd"),
  6. "title" : "MongoDB",
  7. "description" : "MongoDB 是一个 Nosql 数据库",
  8. "by" : "菜鸟教程",
  9. "url" : "http://www.runoob.com",
  10. "tags" : [
  11. "mongodb",
  12. "database",
  13. "NoSQL"
  14. ],
  15. "likes" : 100
  16. }
  17. {
  18. "_id" : ObjectId("593b61fdbcd6757fd2d302fe"),
  19. "title" : "MongoDB 教程",
  20. "description" : "MongoDB 是一个 Nosql 数据库",
  21. "by" : "菜鸟教程",
  22. "url" : "http://www.runoob.com",
  23. "tags" : [
  24. "mongodb",
  25. "database",
  26. "NoSQL"
  27. ],
  28. "likes" : 100
  29. }
  30. {
  31. "_id" : ObjectId("593b6555bcd6757fd2d302ff"),
  32. "title" : "MongoDB 教程",
  33. "description" : "MongoDB 是一个 Nosql 数据库",
  34. "by" : "菜鸟教程",
  35. "url" : "http://www.runoob.com",
  36. "tags" : [
  37. "mongodb",
  38. "database",
  39. "NoSQL"
  40. ],
  41. "likes" : 100
  42. }
可以看到标题(title)由原来的 "MongoDB 教程" 更新为了 "MongoDB"。
以上语句只会修改第一条发现的文档,如果你要修改多条相同的文档,则需要设置 multi 参数为 true。
  1. > db.col.update({'title':'MongoDB 教程'},{$set:{'title':'MongoDB'}},{multi:true})
  2. WriteResult({ "nMatched" : 2, "nUpserted" : 0, "nModified" : 2 })
  3. > db.col.find().pretty() })
  4. {
  5. "_id" : ObjectId("593b6160bcd6757fd2d302fd"),
  6. "title" : "MongoDB",
  7. "description" : "MongoDB 是一个 Nosql 数据库",
  8. "by" : "菜鸟教程",
  9. "url" : "http://www.runoob.com",
  10. "tags" : [
  11. "mongodb",
  12. "database",
  13. "NoSQL"
  14. ],
  15. "likes" : 100
  16. }
  17. {
  18. "_id" : ObjectId("593b61fdbcd6757fd2d302fe"),
  19. "title" : "MongoDB",
  20. "description" : "MongoDB 是一个 Nosql 数据库",
  21. "by" : "菜鸟教程",
  22. "url" : "http://www.runoob.com",
  23. "tags" : [
  24. "mongodb",
  25. "database",
  26. "NoSQL"
  27. ],
  28. "likes" : 100
  29. }
  30. {
  31. "_id" : ObjectId("593b6555bcd6757fd2d302ff"),
  32. "title" : "MongoDB",
  33. "description" : "MongoDB 是一个 Nosql 数据库",
  34. "by" : "菜鸟教程",
  35. "url" : "http://www.runoob.com",
  36. "tags" : [
  37. "mongodb",
  38. "database",
  39. "NoSQL"
  40. ],
  41. "likes" : 100
  42. }
三 save() 方法
1、语法
save() 方法通过传入的文档来替换已有文档。语法格式如下:
db.collection.save(
   <document>,
   {
     writeConcern: <document>
   }
)
参数说明:
document : 文档数据。
writeConcern :可选,抛出异常的级别。
2、实例
以下实例中我们替换了 _id 为 593b6555bcd6757fd2d302ff 的文档数据:
  1. > db.col.save({
  2. ... "_id" : ObjectId("593b6555bcd6757fd2d302ff"),
  3. ... "title" : "MongoDB是一个很好的课程",
  4. ... "description" : "MongoDB 是一个 Nosql 数据库",
  5. ... "by" : "Runoob",
  6. ... "url" : "http://www.runoob.com",
  7. ... "tags" : [
  8. ... "mongodb",
  9. ... "NoSQL"
  10. ... ],
  11. ... "likes" : 130
  12. ... })
  13. WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
替换成功后,我们可以通过 find() 命令来查看替换后的数据
  1. > db.col.find().pretty()
  2. {
  3. "_id" : ObjectId("593b6160bcd6757fd2d302fd"),
  4. "title" : "MongoDB",
  5. "description" : "MongoDB 是一个 Nosql 数据库",
  6. "by" : "菜鸟教程",
  7. "url" : "http://www.runoob.com",
  8. "tags" : [
  9. "mongodb",
  10. "database",
  11. "NoSQL"
  12. ],
  13. "likes" : 100
  14. }
  15. {
  16. "_id" : ObjectId("593b61fdbcd6757fd2d302fe"),
  17. "title" : "MongoDB",
  18. "description" : "MongoDB 是一个 Nosql 数据库",
  19. "by" : "菜鸟教程",
  20. "url" : "http://www.runoob.com",
  21. "tags" : [
  22. "mongodb",
  23. "database",
  24. "NoSQL"
  25. ],
  26. "likes" : 100
  27. }
  28. {
  29. "_id" : ObjectId("593b6555bcd6757fd2d302ff"),
  30. "title" : "MongoDB是一个很好的课程",
  31. "description" : "MongoDB 是一个 Nosql 数据库",
  32. "by" : "Runoob",
  33. "url" : "http://www.runoob.com",
  34. "tags" : [
  35. "mongodb",
  36. "NoSQL"
  37. ],
  38. "likes" : 130
  39. }

猜你喜欢

转载自cakin24.iteye.com/blog/2387004