javascript - 从 MongoDB 驱动程序调用 getUsers() 函数

标签 javascript node.js mongodb sails.js mongodb-query

我目前正在构建一个API应用程序,该应用程序使用Sailsjs(例如用户)检查状态并获取各种类型的数据库(即Mongo、MySQL)的信息,具体取决于用户输入。这是我正在处理的代码片段。本地主机只是我连接的测试数据库,但将来它将由用户提供。

      var mp = require('mongodb-promise');
      var MongoClient = require('mongodb');



  mp.MongoClient.connect("mongodb://@localhost:27017/test")
      .then(function(db){
          db.getUsers().then(function(users){
           res.ok(users);
         })
      })
   .fail(function(err) {
    console.log(err);
})

我正在尝试使用 Promise 来解决异步问题。我遇到的问题是它不起作用。它告诉我 Object[object object] 没有方法“getUsers”。我已经搜索过,似乎找不到有效的解决方案。

如果我将函数更改为以下内容,我会得到一些数据。

 mp.MongoClient.connect("mongodb://@localhost:27017/IMS")
     .then(function(db){
        db.stats().then(function(stats){
         return res.ok(stats);
        })
    })
   .fail(function(err) {
    console.log(err);
    dbObject.vipUp = false;
    }) 

我不确定问题是什么或如何解决。

最佳答案

您在这里所做的是使用 Node native 驱动程序方法来连接和检查数据库。事实上,在此 API 或任何其他 API 中“没有这样的方法”,如 .getUsers()

.getUsers() 函数只是一个“shell 助手”,基本上是这样实现的:

function (args) {
    var cmdObj = {usersInfo: 1};
    Object.extend(cmdObj, args);
    var res = this.runCommand(cmdObj);
    if (!res.ok) {
        var authSchemaIncompatibleCode = 69;
        if (res.code == authSchemaIncompatibleCode ||
                (res.code == null && res.errmsg == "no such cmd: usersInfo")) {
            // Working with 2.4 schema user data
            return this.system.users.find({}).toArray();
        }

        throw Error(res.errmsg);
    }

    return res.users;
}

所以你应该在这里看到的是,这通常包装一个“命令”形式,或者以其他方式回退到与 MongoDB 2.4 的兼容性来查询当前数据库上的 system.users 集合.

因此,您需要使用.command(),而不是调用不存在的方法。方法替代:

mp.MongoClient.connect("mongodb://@localhost:27017/test")
      .then(function(db){
          db.command({ "usersInfo": 1}).then(function(users){
           res.ok(users);
         })
      })
   .fail(function(err) {
    console.log(err);
})

或者在连接到 MongoDB 2.4 实例的情况下,然后从 .collection() 获取:

mp.MongoClient.connect("mongodb://@localhost:27017/test")
      .then(function(db){
          db.collection('system.users').find().toArray().then(function(users){
           res.ok(users);
         })
      })
   .fail(function(err) {
    console.log(err);
})
无论如何,您确实应该在应用程序的其他位置建立数据库连接(或重新使用来自另一个存储的底层驱动程序连接),然后在已建立的连接上调用方法。这总是比根据您要检索的信息的请求创建连接更好。

此外,最近版本的 node native driver开箱即用的支持 promise 。因此,可能不需要进行任何其他配置,具体取决于您打算如何使用它。

关于javascript - 从 MongoDB 驱动程序调用 getUsers() 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32063113/

相关文章:

javascript - Node.js 外部函数调用

javascript - 错误 myFunction(...).then 不是函数

mongodb - 我在哪里可以下载 64 位 ubuntu/linux 中的 pymongo

javascript - 改变word中的字符

javascript - 在输入文本中添加图像

javascript - 使用bulkDelete时出现 promise 拒绝错误

java - Spring数据MongoDB : search like on multiple fields

c# - 使用 c# 连接 Mongodb 并出现统一错误

javascript - 如何使用javascript显示错误消息而不发出警报

javascript - 为什么在 jQuery 中执行某些脚本之前无法将光标更改为 "progress"?