使用javascript对象

时间:2015-07-27 18:35:35

标签: javascript mongodb meteor

相关:mongodb/meteor collection check if subdocument field exists when field is a variable

我正在尝试通过构建具有一些可变字段名称的对象来查询Meteor集合。当对象有一个字段时,这可以工作,例如

var query = {};
query['myField.'+myVariable] = {$exists: true};
Collection.find(query); //works fine

但我需要使用多个选择器进行查询。例如,我需要检查带有变量的字段名称是否存在,还检查是否有其他field = true,以及是否有其他field =变量。所以我试图找到一种构建查询对象的通用方法。我尝试过以下方法:

var query = {};
query['myField.'+myVariable] = {$exists: true};
query[newField] = false;
Collection.find(query);

这不起作用。我不确定是不是因为'newField'不是Object类型的东西。

我也试过使用$和selector来查看是否有效,但我不认为我使用的语法完全正确...

var query = {};
var object = {};
object['myField'.+myVariable] = {$exists: true};
query['$and'] = [object, {newField: false}];
Collection.find(query);

这也行不通。我试图用mongo $和选择器构建,它使用数组工作。

如何使用javascript对象表示法和对象文字语法构建Meteor集合查询?我觉得其中任何一个都应该有用。

具体来说,我正在寻找以下内容(半伪代码,因为获取带有点符号的子文档/子对象不适用于mongo查询)

Collection.find({correlated: false, readBy.(Meteor.userId()): {$exists: true} ...)

我还认为这应该有效:

var query = {};
query['myField.'+myVariable] = {$exists: true};
Collection.find(query, {otherField: false}) 
//OR 
var query2 = {};
query['priority'] = false;
Collection.find(query, query2)

但他们都没有。

编辑:示例文档。我想找到这样的文档,使得当前用户ID不是readBy字段并且具有相关性:false

{
    "_id" : ObjectId("55b6868906ce5d7b1ac6af10"),
    "title" : "test",
    "correlated" : "false",
    "readBy" : {
        "DXqLhesDEJq4ye8Dy" : ISODate("2015-07-27T18:29:43.592Z")
    }
}

1 个答案:

答案 0 :(得分:1)

find只有一个选择器参数。所以这个:

Collection.find(query, {otherField: false})

不正确。 query必须包含有关otherField的信息。仔细看看这个示例代码:

// 'readBy.abc123'
var key = 'readBy.' + Meteor.userId();

// build the selector by parts
var selector = {correlated: false};
selector[key] = {$exists: false};

// selector should now be something like:
// {correlated: false, 'readBy.abc123': {$exists: false}}
// note that these are ANDed together so all conditions must be true

// here's a cursor you can use to fetch your documents
var cursor = Collection.find(selector);

// log one of the selected documents
console.log(Collection.findOne(selector));