sql >> Base de Datos >  >> NoSQL >> MongoDB

establecer valores predeterminados para matrices de mangosta en el nodo js

Mongoose le permite "separar" definiciones de esquema. Tanto para la "reutilización" general como para la claridad del código. Así que una mejor manera de hacer esto es:

// general imports
var mongoose = require('mongoose'),
    Schema = mongoose.Schema;

// schema for params
var paramSchema = new Schema({
    "name": { "type": String, "default": "something" },
    "value": { "type": String, "default": "something" }
});

// schema for features
var featureSchema = new Schema({
    "name": { "type": String, "default": "something" }
    "params": [paramSchema]
});

var appSchema = new Schema({
    "appFeatures": [featureSchema]
});

// Export something - or whatever you like
module.export.App = mongoose.model( "App", appSchema );

Por lo tanto, es "limpio" y "reutilizable" si está dispuesto a hacer que las definiciones de "Esquema" formen parte de módulos individuales y use el sistema "requerir" para importar según sea necesario. Incluso puede "introspeccionar" las definiciones de esquema de los objetos "modelo" si no desea "modular" todo.

Sin embargo, en su mayoría, le permite especificar claramente "lo que desea" para los valores predeterminados.

Para un valor predeterminado más complejo, probablemente desee hacer esto en un gancho "preguardado". Como un ejemplo más completo:

var async = require('async'),
    mongoose = require('mongoose'),
    Schema = mongoose.Schema;

var paramSchema = new Schema({
  "name": { "type": String, "default": "something" },
  "value": { "type": String, "default": "something" }
});

var featureSchema = new Schema({
  "name": { "type": String, "default": "something" },
  "params": [paramSchema]
});

var appSchema = new Schema({
  "appFeatures": [featureSchema]
});

appSchema.pre("save",function(next) {
  if ( !this.appFeatures || this.appFeatures.length == 0 ) {
    this.appFeatures = [];
    this.appFeatures.push({
      "name": "something",
      "params": []
    })
  }

  this.appFeatures.forEach(function(feature) {
    if ( !feature.params || feature.params.length == 0 ) {
      feature.params = [];
      feature.params.push(
       {  "name": "a", "value": "A" },
       {  "name": "b", "value": "B" }
      );
    }
  });
  next();
});


var App = mongoose.model( 'App', appSchema );

mongoose.connect('mongodb://localhost/test');


async.series(
  [
    function(callback) {
      App.remove({},function(err,res) {
        if (err) throw err;
        callback(err,res);
      });
    },
    function(callback) {
      var app = new App();
      app.save(function(err,doc) {
        if (err) throw err;
        console.log(
          JSON.stringify( doc, undefined, 4 )
        );
        callback()
      });
    },
    function(callback) {
      App.find({},function(err,docs) {
        if (err) throw err;
        console.log(
          JSON.stringify( docs, undefined, 4 )
        );
        callback();
      });
    }
  ],
  function(err) {
    if (err) throw err;
    console.log("done");
    mongoose.disconnect();
  }
);

Podría limpiar eso e introspeccionar la ruta del esquema para obtener valores predeterminados en otros niveles. Pero básicamente quiere decir que si esa matriz interna no está definida, entonces va a completar los valores predeterminados como están codificados.