Получение данных из mlab heroku

Я следовал руководству, чтобы изучить приложение Express.js, которое выполняет основные операции CRUD из MongoDB. Все операции, созданные локально, работают нормально. В качестве следующего шага (не в учебнике) мне нужно было интегрировать mLab, предоставленный Heroku для MongoDB, чтобы отправить приложение в Heroku.

Теперь мне нужно внести необходимые изменения в соединение с мангустом, так как я перехожу с локальной базы данных на mLab. Я внес необходимые изменения, но теперь приложение выдает ошибку.

жалобаController.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
    });
});
};

жалобаModel.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);
 }

жалобаModel.js (при подключении к mLab выдает ошибку)

var mongoDB = "MongoDB URI";

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

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

Здесь я получаю следующую ошибку, когда я даю запрос на получение. Я понял, что есть проблема с экспортом модуля жалоб, но любое предложение или идея будут полезны.

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)
Использование JavaScript и MongoDB
Использование JavaScript и MongoDB
Сегодня я собираюсь вкратце рассказать о прототипах в JavaScript, а также представить и объяснить вам работу с базой данных MongoDB.
4
0
165
1

Ответы 1

Из того, что я вижу в коде. жалобаКонтроллер будет использоваться маршрутизатором express.js. Я прав?

Я также вижу в жалобаModel.js, что для экспортированной вами функции get требуются 2 параметра: фильтр и ограничение. Но в Файл контроллера вы вообще не предоставляете ни одного из этих аргументов.

Я еще не проверял это сам, но попробуйте изменить жалобаModel.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.info("connection established!!!");

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

И измените жалобаController.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
        });
      }
    })
  );
};

Другие вопросы по теме