gpt4 book ai didi

node.js - 使用 $push 时如何验证数组长度?

转载 作者:太空宇宙 更新时间:2023-11-03 23:18:47 26 4
gpt4 key购买 nike

我试图限制用户可以添加到我的架构之一的数组字段中的元素数量。我目前正在使用 Schema.findOneAndUpdate();$push 运算符将元素添加到数组中。

我尝试的第一件事是 StackOverflow 上另一个答案给出的解决方案,即:https://stackoverflow.com/a/29418656/6502807该解决方案向模式定义中的字段添加了验证函数。通过将 runValidators 设置为 true,我确实获得了使用 Schema.findOneAndUpdate() 运行的函数。然而,就在那时,我偶然发现了下一个问题。在 Mongoose 文档的“验证”一章的末尾,它说:

Also, $push, $addToSet, $pull, and $pullAll validation does not run any validation on the array itself, only individual elements of the array.

因此,在使用 $pull 时尝试检查数组长度不起作用。它只是每次都向验证函数提供一个空数组,而不管数据库中的实际内容如何。

接下来我尝试的是使用 pre 钩子(Hook)。这也没有取得任何成功。由于某种原因,即使将 runValidators 设置为 true,它也没有执行 Hook 。这就是我定义所述钩子(Hook)的方式:

Settings.pre('update', async function (next) {
if (this.messages.length > MAX_MESSAGES) {
throw new Error('Too many messages');
} else {
next();
}
});

编辑:该函数未触发的原因是因为我使用的是findOneAndUpdate而不是update,此问题已修复并且该函数现在可以运行。然而,上面的解决方案代码不起作用。

带有数组的架构如下所示:

const Settings = new mongoose.Schema({
// A lot more fields not relevant to this question
messages: {
type: [{
type: String
}]
}
});

另外值得一提的是,这些更新语句是与其他选项结合使用的。我需要更新语句的行为类似于更新或插入,因此我的完整选项集如下所示:

{
runValidators: true,
setDefaultsOnInsert: true,
upsert: true,
new: true
}

当使用这样的预钩子(Hook)设置执行查询时,可以超出数组限制,而不会引发任何验证错误。

此时我想知道是否有任何明智的方法可以进行这样的最大长度检查,而不必在 Mongoose 的抽象层之外自己进行。

我正在使用在 Node v9.11.1 上运行的 Mongoose 5.2.6 和 MongoDB 4.0.0。

非常感谢任何帮助!

最佳答案

如果您使用的是 mongodb 和 mongoose 的最新版本,那么您可以使用 $expr运算符

const udpate = await db.collection.update(
{ $expr: { $gt: [{"$size": "$messages" }, MAX_MESSAGES] }},
{ update }
)

关于node.js - 使用 $push 时如何验证数组长度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52064067/

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