gpt4 book ai didi

node.js - NodeJS/Mongoose/MongoDB - 拉(从数组中)不起作用

转载 作者:IT老高 更新时间:2023-10-28 13:32:09 25 4
gpt4 key购买 nike

我正在尝试从数组(子文档)中提取/删除值。

示例文档:

{
_id: 5150a1199fac0e6910000002,
name: 'some name,
items: [{
id: 23,
name: 'item name 23'
},{
id: 24,
name: 'item name 24'
}]
}

我已经从 mongo 中提取了该文档。我正在尝试:

var left = object.items.pull({id: 24});
console.log(left)

输出:

[{
id: 23,
name: 'item name 23',
_id: 5150a1199fac0e6910000045
},{
id: 24,
name: 'item name 24',
_id: 5150a1199fac0e6910000002
}]

看来我已经有问题了。从 pull 调用返回的数组应该是 pull 之后数组中剩下的内容。不知道为什么它没有从项目数组中提取。这是否仅支持通过 ObjectId ant 而不是用户定义的字段进行拉取?

我调用保存:

object.save();

Mongoose 将其记录为查询:

Mongoose: mycollection.update({ _id: ObjectId("5150901ac345824a07000002"), __v: 3 }) 
{ '$inc': { __v: 1 }, '$pull':
{ attachments: { _id: { '$in': [ ObjectId("5150c64d63773efb1f000002") ] } } } } {}

这说明了为什么我的文档没有被删除。应该删除的数组项的_id是:

_id: 5150a1199fac0e6910000002

mongoose 发送到数据库要删除的项目是:

ObjectId("5150c64d63773efb1f000002")

任何想法我做错了什么?我正在尝试通过 _id 以外的方式删除,不确定这是否可能,但从文档看来是。

最佳答案

我发现 $pull 命令对我也不起作用,除非我在参数列表中包含回调。

在我的情况下,这种格式不起作用:

UserAlerts.findOneAndUpdate({userId: userId}, {$pull: {alerts: {_id: alertId}}});

但这种格式确实:

UserAlerts.findOneAndUpdate({userId: userId}, {$pull: {alerts: {_id: alertId}}}, function(err, data){
console.log(err, data);
});

根据文档,似乎两者都应该工作,但没有。原因是因为第一种方式需要你在返回的对象上调用 .exec() ,而回调版本会自动调用 exec() 。也给我造成了一些困惑。

所以你需要做这样的事情:

UserAlerts.findOneAndUpdate({userId: userId}, {$pull: {alerts: {_id: alertId}}}).exec();

关于node.js - NodeJS/Mongoose/MongoDB - 拉(从数组中)不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15625633/

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