Mongodb:db未定义连接

时间:2018-01-03 14:50:51

标签: mongodb mongodb-query aggregation-framework loopbackjs loopback

我正在尝试通过本机驱动程序访问mongodb。

当我在远程方法中使用connect方法时。我成功连接,但我得到“未定义”作为数据库对象

目的:从集合中获取所有字段的名称。

Activation.getUserFields = function (id, callbackFn) {
        Activation.app.dataSources.mongoConnector.connect(function (errconnect, mdb) {
            if (errconnect) callbackFn(errconnect, {});
            else {
                console.log('mdb', mdb);
                var mr = mdb.runCommand({
                    "mapreduce": "Visit",
                    "map": function () {
                        for (var key in this) { emit(key, null); }
                    },
                    "reduce": function (key, stuff) { return null; },
                    "out": "Visit" + "_keys"
                });

                mdb[mr.result].distinct("_id").toArray(function (errFields, docFields) {
                    if (errFields) callbackFn(errFields, {});
                    else {
                        callbackFn(null, docFields);
                    }
                });
            }
        });
    };
};

我在这里缺少什么?

1 个答案:

答案 0 :(得分:0)

在LoopBack中您可以通过以下方式访问模型和集合:

Plz尝试:

const ActivationCollection = Activation.getDataSource().connector.collection("Activation");
ActivationCollection.runCommand({
                "mapreduce": "Visit",
                "map": function () {
                    for (var key in this) { emit(key, null); }
                },
                "reduce": function (key, stuff) { return null; },
                "out": "Visit" + "_keys"
            });