在MongoDB中更新嵌套文档中的值

huangapple go评论75阅读模式
英文:

Updating value in a nested document in mongoDB

问题

I have the following schema:

  1. const itemsSchema = new mongoose.Schema({
  2. name: String,
  3. checkedValue: String
  4. });
  5. const listSchema = new mongoose.Schema({
  6. name: String,
  7. items: [itemsSchema]
  8. });
英文:

I have the following schema:

  1. const itemsSchema = new mongoose.Schema({
  2. name: String,
  3. checkedValue: String
  4. });
  5. const listSchema = new mongoose.Schema({
  6. name: String,
  7. items: [itemsSchema]
  8. });

I want to update data like this: listSchema>items>checkedValue. I have performed the following operation:

  1. db.collections.update({
  2. "name": "Home"
  3. },
  4. {
  5. "$set": {
  6. "items.$[i].checkedValue": "On"
  7. }
  8. },
  9. {
  10. arrayFilters: [
  11. {
  12. "i.items._id": ObjectId("646ec7836f8ba817e80e3372")
  13. }
  14. ]
  15. })

But I am getting an error no document found. How can I update the specific document?

Sample data:

  1. [
  2. {
  3. _id: ObjectId("646ec7916f8ba817e80e3377"),
  4. name: 'Home',
  5. items: [
  6. {
  7. name: 'home 1',
  8. checkedValue: 'Off',
  9. _id: ObjectId("646ec7966f8ba817e80e3380")
  10. },
  11. {
  12. name: 'home 2',
  13. checkedValue: 'Off',
  14. _id: ObjectId("646ec79a6f8ba817e80e338c")
  15. },
  16. {
  17. name: 'home 3',
  18. checkedValue: 'Off',
  19. _id: ObjectId("646efd38b1bc960c52ce5078")
  20. }
  21. ],
  22. __v: 3
  23. },
  24. {
  25. _id: ObjectId("646ed4136f8ba817e80e339b"),
  26. name: 'School',
  27. items: [
  28. {
  29. name: 'School 1',
  30. checkedValue: 'Off',
  31. _id: ObjectId("646efd45b1bc960c52ce509c")
  32. },
  33. {
  34. name: 'School 2',
  35. checkedValue: 'Off',
  36. _id: ObjectId("646efd4cb1bc960c52ce50a9")
  37. },
  38. {
  39. name: 'School 3',
  40. checkedValue: 'Off',
  41. _id: ObjectId("646efd52b1bc960c52ce50b1")
  42. }
  43. ],
  44. __v: 4
  45. }
  46. ]

答案1

得分: 1

  1. db.collection.update({
  2. name: "Home"
  3. },
  4. {
  5. $set: {
  6. "items.$[i].checkedValue": "On"
  7. }
  8. },
  9. {
  10. arrayFilters: [
  11. {
  12. "i._id": ObjectId("646ec7966f8ba817e80e3380")
  13. }
  14. ]
  15. })
英文:

the object id you gave in the array filter is not in the items list. anyway even if it did the way you have written arrayFilters has to be changed to i._id. Think of i as an individual element in the items array

  1. db.collection.update({
  2. name: "Home"
  3. },
  4. {
  5. $set: {
  6. "items.$[i].checkedValue": "On"
  7. }
  8. },
  9. {
  10. arrayFilters: [
  11. {
  12. "i._id": ObjectId("646ec7966f8ba817e80e3380")
  13. }
  14. ]
  15. })

playground

答案2

得分: 1

首先,你的查询语句在我的视角下是不正确的。因为你使用了 db.collections.update({ })。在这里,应该是 db.collection.update({ })

之后,要执行查询,你需要将它写成:

  1. arrayFilters: [
  2. {
  3. "i._id": ObjectId("646ec7966f8ba817e80e3380")
  4. }
  5. ]

然后你的第一个索引项将会被更新。

英文:

First of all, your written query is incorrect as my perspective. Because you have used db.collections.update({ }). In here, it should be db.collection.update({ })

After that, to perform the query you need to write it as,

  1. arrayFilters: [
  2. {
  3. "i._id": ObjectId("646ec7966f8ba817e80e3380")
  4. }
  5. ]

Then your first index item will be updated.

答案3

得分: 0

When sending value to the arrayFilter, I have to convert the _id to an ObjectId. This is done by the following code:

  1. const checkedItemId = req.body.checkedItemId;
  2. const checkedItemObjectId = new mongoose.Types.ObjectId(checkedItemId);

And to update the value in the subdocument, the following updateOne() method worked fine for me:

  1. List.collection.updateOne(
  2. { 'items.checkedValue': 'Off' },
  3. { '$set': { 'items.$[element].checkedValue': 'On' } },
  4. {
  5. arrayFilters: [
  6. {
  7. 'element._id': { '$eq': checkedItemObjectId }
  8. }
  9. ]
  10. })
英文:

When sending value to the arrayFilter, I have to convert the _id to an ObjectId. This is done by the following code:

  1. const checkedItemId = req.body.checkedItemId;
  2. const checkedItemObjectId = new mongoose.Types.ObjectId(checkedItemId);

And to update the value in the subdocument, the following updateOne() method worked fine for me:

  1. List.collection.updateOne(
  2. { 'items.checkedValue': 'Off' },
  3. { '$set': { 'items.$[element].checkedValue': 'On' } },
  4. {
  5. arrayFilters: [
  6. {
  7. 'element._id': { '$eq': checkedItemObjectId }
  8. }
  9. ]
  10. })

huangapple
  • 本文由 发表于 2023年5月25日 14:18:07
  • 转载请务必保留本文链接:https://go.coder-hub.com/76329403.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定