gpt4 book ai didi

mongodb - 使用 SailsJS 更新 MongoDb 中的对象数组

转载 作者:可可西里 更新时间:2023-11-01 09:35:48 24 4
gpt4 key购买 nike

我在 MongoDB 中有一条记录,格式如下:

  {
attachment: 'xxxxxxx',
createdAt: TueAug04201514: 52: 23GMT+0400(GST),
text: 'xxxxxxx',
sender: '55784247c95c59cc746904e1',
status: [
{
user: '5589464675fc0892757d170e',
is_read: 0
},
{
user: '55a4a39d5c0bf23d21e6c485',
is_read: 0
},
{
user: '55a4a38e5c0bf23d21e6c483',
is_read: 0
},
{
is_read: 0,
user: '55784247c95c59cc746904e1'
}
],
thread: '55c0946b80320adb3fd04d0e',
updatedAt: TueAug04201515: 45: 55GMT+0400(GST),
id: '55c09967708b73184558fbc8'
}

我想更新 status 数组中的 is_read。这是我尝试过的。

      Messages.update({
thread: threadIds,
status: { $elemMatch: { user: user.id, is_read: 0 } }
},
{ $set: { "status.$.is_read": 1 } })

但是相同的查询在 mongodb shell 中运行得非常好。如果我遗漏了什么,谁能指导我?顺便说一下,我在使用 Waterline ORMSailsJS 中运行此查询。

最佳答案

要使用与 mongo shell 相同的查询,您必须使用 Model.native因为 Sails 基于 Waterline,它的查询语言与 Mongo 略有不同。

我还没有尝试过这个,但我敢打赌这应该可以做到:

  Messages.update({
thread: threadIds,
'status.user': user.id,
'status.is_read': 0
},
{ 'status.is_read': 1 }, callback);

关于mongodb - 使用 SailsJS 更新 MongoDb 中的对象数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31808811/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com