gpt4 book ai didi

javascript - Mongoskin 查询使用变量作为查询键检查文档 $ 是否存在

转载 作者:行者123 更新时间:2023-12-03 09:27:14 24 4
gpt4 key购买 nike

使用 Mongoskin,我想检查 MongoDB 集合中是否存在文档,其中每个文档都有一个唯一的键和一个数组作为其值。此代码完美运行:

db.collection('buyerRec').find({ "abcd" : { $exists : true }}, { _id:0 }).toArray(function(err, doc) {
...
});

找到“abcd”文档。然而,在实际的系统设计中,文档的查询键是事先不知道的,所以我需要使用一个变量来代替“abcd”。我找不到有效的组合。在这两种失败的情况下,它总是返回一个空数组 -

失败示例 1:

console.log("idCode: " + typeof idCode + " " + idCode); // idCode: string abcd

db.collection('buyerRec').find({ idCode : { $exists : true }}, { _id:0 }).toArray(function(err, doc) {
...
});

失败示例2:

console.log("idCode: " + typeof idCode + " " + idCode); // idCode: string abcd

var query = "\"" + idCode + "\"";
console.log("query: " + typeof query + " " + query); // query: string "abcd"

db.collection('buyerRec').find({ query : { $exists : true }}, { _id:0 }).toArray(function(err, doc) {
...
});

对我来说,这两个失败示例中的一个应该重复第一个示例的预期操作。有人可以指导我如何重新编码吗?谢谢。

最佳答案

我认为你的问题可能是creating js object using variables for property name 。您可以尝试如下操作:

 fieldName = "abcd"
var query = {};
query[fieldName] = {"$exists": true};
db.collection('buyerRec').find(query)

但是上面的代码实际上不太好,因为fieldName没有作为参数传递。在我的 .mongorc.js 中(mongo shell 每次启动时都会加载 .mongorc.js),我为这种情况编写了函数,仅供引用。

 DBCollection.prototype.has = function(fieldName) {
var query = {}; // construct a empty object
query[fieldName] = {"$exists": true};
return db.getCollection(this._shortName).find(query).pretty();
}

然后你可以编写如下查询:

 db.buyerRec.has("abc") // in mongo shell

但是,我认为你实际上必须编写自己的函数,因为我的函数只是专注于检查某个键是否存在。 不管怎样,希望对你有帮助。

关于javascript - Mongoskin 查询使用变量作为查询键检查文档 $ 是否存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31632876/

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