我正在尝试通过本机驱动程序访问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);
}
});
}
});
};
};
我在这里缺少什么?
答案 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"
});