mongodb - 从 mlab heroku 检索数据

标签 mongodb express heroku mongoose

我按照教程学习了从 MongoDB 执行基本 CRUD 操作的 Express.js 应用程序。在本地创建的所有操作都可以正常工作。 作为下一步(不在教程中),我需要集成 Heroku 为 MongoDB 提供的 mLab,以便将应用程序推送到 Heroku。

现在,我需要对 mongoose 连接进行必要的更改,因为我要从本地数据库迁移到 mLab。我进行了必要的更改,但现在应用程序抛出错误。

complaintController.js(获取请求和使用模型的类)

Complaint = require('./complaintModel');
exports.index = function (req, res) {
Complaint.get(function (err, complaints) {      //GET function
    if (err) {
        res.json({
            status: "error",
            message: err,
        });
    }
    res.json({
        status: 200,
        message: "Complaints retrieved successfully",
        data: complaints
    });
});
};

complaintModel.js(本地 MongoDB 工作正常)

var mongoose = require('mongoose');
var complaintSchema = mongoose.Schema({
name: {
    type: String,
    required: true
},
});


 // Export Complaint model

 var Complaint = module.exports = mongoose.model('complaint', complaintSchema);
 module.exports.get = function (callback, limit) {
     Complaint.find(callback).limit(limit);
 }

complaintModel.js(连接到 mLab 抛出错误)

var mongoDB = "MongoDB URI";

var connection = mongoose.createConnection(mongoDB,
{    
  User: 'username',
  Password: 'pass'
});

var Complaint;
connection.on('open', function() {
  console.log('connection established!!!');
  Complaint = module.exports = connection.model('master_complaint', complaintSchema);
  module.exports.get = function (callback, limit) {
    Complaint.find(callback).limit(limit);
  }
});

这里,当我发出 get 请求时出现以下错误我知道投诉模块存在导出问题,但任何建议或想法都会有所帮助。

TypeError: Complaint.get is not a function
at exports.index (R:\Workings\PersWork\web\webpack-demo\controller\complaintController.js:6:15)
at Layer.handle [as handle_request] (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\layer.js:95:5)
at next (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\route.js:137:13)
at Route.dispatch (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\route.js:112:3)
at Layer.handle [as handle_request] (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\layer.js:95:5)
at R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\index.js:281:22
at Function.process_params (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\index.js:335:12)
at next (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\index.js:275:10)
at Function.handle (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\index.js:174:3)
at router (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\index.js:47:12)
at Layer.handle [as handle_request] (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\layer.js:95:5)
at trim_prefix (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\index.js:317:13)
at R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\index.js:284:7
at Function.process_params (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\index.js:335:12)
at next (R:\Workings\PersWork\web\webpack-demo\node_modules\express\lib\router\index.js:275:10)
at jsonParser (R:\Workings\PersWork\web\webpack-demo\node_modules\body-parser\lib\types\json.js:110:7)

最佳答案

从我在代码中看到的。 complaintController 将由 express.js 路由器使用,我说得对吗?

我还在 complaintModel.js 中看到,您导出的 get 函数需要 2 个参数,即过滤器和限制。但在 Controller 文件中,您根本没有提供任何这些参数。

我自己还没有测试过这个,但是试着把你的 complaintModel.js 改成这个

var mongoose = require("mongoose");

var complaintSchema = mongoose.Schema({
  name: {
    type: String,
    required: true
  }
});

var Complaint = mongoose.model("master_complaint", complaintSchema);

// Exports the get function
module.exports.get = function(filter, limit, callback) {
  var mongoDB = "MongoDB URI";

  var connection = mongoose.createConnection(mongoDB, {
    User: "username",
    Password: "pass"
  });

  connection.on("open", function() {
    console.log("connection established!!!");

    Complaint.find(filter)
      .limit(limit)
      .exec()
      .then(results => {
          callback(undefined, results)
      })
      .catch(err => {
          console.log(err);
          callback("ERROR: Can't query the collection", undefined)
      });
  });
};

并将 complaintController.js 更改为以下内容

var Complaint = require("./complaintModel");

module.exports.index = function(req, res) {
  var params = req.query;
  const filter = params.filter;
  const limit = params.limit;

  Complaint.get(
    filter,
    limit,
    (err,
    complaints => {
      if (err) {
        res.json({
          status: "error",
          message: err
        });
      } else {
        res.json({
          status: 200,
          message: "Complaints retrieved successfully",
          data: complaints
        });
      }
    })
  );
};

关于mongodb - 从 mlab heroku 检索数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55117725/

相关文章:

ruby-on-rails - 使用 SQLite 3 将 RoR 应用程序部署到 Heroku 失败

mysql - 将 mysql 推送到 heroku 时出现关系错误

javascript - 将变量传递给nodemailer中的html模板

node.js - Node js,到处都需要或添加一个属性到req

javascript - 如何将笔记的多个修订合并为一个版本?

javascript - 根据 mongodb 中的字段对文档进行分组和收集

node.js - Express 4 - 将 res.json 与 promise.then 链接起来不起作用

Node.JS、Express 和 MongoDB::多个集合

ruby-on-rails - 将 Wordpress 博客路由到 Rails 子文件夹 - 博客链接未更改

java - MongoDB (Java) - 如何运行保存在 javascript 文件中的查询?