如何在Meteor的Mongo查询中使用变量作为字段名称?

时间:2012-08-19 03:04:36

标签: javascript mongodb meteor

如何在Meteor应用程序的Mongo查询中将变量用作字段名称。

这是一个例子......

在大写子集的父ID的集合名称之后,它会在我的请求控制器集合上运行查找。孩子是用户字段。

window[Meteor.request.controller.capitalise()]["find"]({ _id: Session.get('parent_id'), users: params.child }).count()

正如您所看到的,我的控制器是集合项的变量名,它允许我有一行代码来查找控制器/集合的子代,但我需要能够将子字段名设置为变量。在上面的示例中,用户但我希望它是变量名。

我试过这个,但它不起作用。

window[Meteor.request.controller.capitalise()]["find"]({ _id: Session.get('parent_id'), [Session.get('child_collection_name').decapitalise()]: params.child }).count()

,其中

Session.get('child_collection_name').decapitalise()

返回用户

有什么想法吗?如果我能弄清楚如何在meteor中使用mongo查询中的变量名,那么它将大大减少我的代码占用量。

1 个答案:

答案 0 :(得分:14)

查询只是一个JavaScript对象,因此您可以逐步构建它:

var query = { _id: Session.get('parent_id') };
var myCustomField = Session.get('child_collection_name').decapitalise();
var myCustomValue = params.child;
query[myCustomField] = myCustomValue;
var count = SomeCollection.find(query).count();

这样做可以吗?