MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Как да използвате събитията, пазете логиката на mongodb извън манипулаторите на заявки node.js

Ето решението, което измислих.

Използвах mongojs което значително опростява интерфейса на mongodb -- с цената на гъвкавост в конфигурацията -- но скрива вложените обратни извиквания, които драйверът на mongodb изисква. Освен това прави синтаксиса много по-подобен на mongo клиента.

След това обвивам обекта HTTP Response в затваряне и предавам това затваряне на метода на заявка mongodb в обратно извикване.

var MongoProvider = require('./MongoProvider');
MongoProvider.setCollection('things');

exports.index = function(request, response){
    function sendResponse(err, data) {
        if (err) { 
            response.send(500, err);
        }    
        response.send(data);
    };

    MongoProvider.fetchAll(things, sendResponse);
};

Той все още по същество просто предава обекта на отговора на доставчика на базата данни, но като го опакова в затваряне, което знае как да обработва отговора, запазва тази логика извън моя модул на база данни.

Леко подобрение е използването на функция за създаване на затваряне на манипулатор на отговор извън моя манипулатор на заявки:

function makeSendResponse(response){
    return function sendResponse(err, data) {
        if (err) {
            console.warn(err);
            response.send(500, {error: err});
            return;
        }

        response.send(data);
    };
}

Така че сега моят манипулатор на заявки изглежда просто така:

exports.index = function(request, response) {
    response.send(makeSendResponse(response));
}

И моят MongoProvider изглежда така:

var mongojs = require('mongojs');

MongoProvider = function(config) {
this.configure(config);
    this.db = mongojs.connect(this.url, this.collections);
}

MongoProvider.prototype.configure = function(config) {
    this.url = config.host + "/" + config.name;
    this.collections = config.collections;
}

MongoProvider.prototype.connect = function(url, collections) {
    return mongojs.connect(this.url, this.collections);
}

MongoProvider.prototype.fetchAll = function fetchAll(collection, callback) {
    this.db(collection).find(callback);
}

MongoProvider.prototype.fetchById = function fetchById(id, collection, callback) {
    var objectId = collection.db.bson_serializer.ObjectID.createFromHexString(id.toString());

    this.db(collection).findOne({ "_id": objectId }, callback);
}

MongoProvider.prototype.fetchMatches = function fetchMatches(json, collection, callback) {
    this.db(collection).find(Json.parse(json), callback);
}

module.exports = MongoProvider;

Мога също така да разширя MongoProvider за конкретни колекции, за да опростя API и да направя допълнителна проверка:

ThingsProvider = function(config) {
    this.collection = 'things';
    this.mongoProvider = new MongoProvider(config);
    things = mongoProvider.db.collection('things');
}

ThingsProvider.prototype.fetchAll = function(callback) {
    things.fetchAll(callback);
}

//etc...

module.exports = ThingsProvider;


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. как да използвам агрегатна функция в meteor

  2. Време е да живеете в mongodb, mongoose не работят. Документите не се изтриват

  3. Как да конфигурирате Embedded MongDB за тестване на интеграция в приложение за Spring Boot?

  4. проблем с отворена връзка на mongodb

  5. Как MongoDB избира планове за кандидати