sql >> Databáze >  >> NoSQL >> MongoDB

Pole výsledků Mongoose/MongoDB jsou v JavaScriptu nedefinovaná

Řešení

Můžete zavolat toObject pro přístup k polím. Například:

var itemObject = item.toObject();
console.log(itemObject.title); // "foo"

Proč

Jak uvádíte, skutečná pole jsou uložena v _doc pole dokumentu .

Ale proč console.log(item) => { title: "foo", content: "bar" } ?

Ze zdrojového kódu mongoose(document.js) můžeme zjistit, že toString metoda Document zavolejte toObject metoda. Tedy console.log zobrazí pole „správně“. Zdrojový kód je uveden níže:

var inspect = require('util').inspect;

...

/**
 * Helper for console.log
 *
 * @api public
 */
Document.prototype.inspect = function(options) {
  var isPOJO = options &&
    utils.getFunctionName(options.constructor) === 'Object';
  var opts;
  if (isPOJO) {
    opts = options;
  } else if (this.schema.options.toObject) {
    opts = clone(this.schema.options.toObject);
  } else {
    opts = {};
  }
  opts.minimize = false;
  opts.retainKeyOrder = true;
  return this.toObject(opts);
};

/**
 * Helper for console.log
 *
 * @api public
 * @method toString
 */

Document.prototype.toString = function() {
  return inspect(this.inspect());
};


  1. Nastavení dynamické cesty v redis.conf pomocí proměnné prostředí

  2. Mohu použít '$set' na vložený dokument, když použiji proměnnou jako název souboru v MongoDB?

  3. Jak mohu použít Map/Reduce v MongoDB?

  4. Node.js – Vytváření vztahů s Mongoose