Betrachten Sie den folgenden Code, den ich verwende, um die Daten von meinem lokalen MongoDB-Server abzurufen.Wie Umbenennen/Alias-Feld (e) beim Abrufen von MongoDB aus Abfrage über MongoDB-Node.JS native Laufwerk?
var Db = require('mongodb').Db,
MongoClient = require('mongodb').MongoClient,
Server = require('mongodb').Server,
ReplSetServers = require('mongodb').ReplSetServers,
ObjectID = require('mongodb').ObjectID,
Binary = require('mongodb').Binary,
GridStore = require('mongodb').GridStore,
Code = require('mongodb').Code,
BSON = require('mongodb').pure().BSON,
assert = require('assert');
var db = new Db('test', new Server('localhost', 27017));
db.open(function(err, db) {
db.createCollection('simple_limit_skip_find_one_query', function(err, collection) {
assert.equal(null, err);
collection.insert([{a:1, b:1}, {a:2, b:2}, {a:3, b:3}], {w:1}, function(err, result) {
assert.equal(null, err);
collection.findOne({a:1}, {fields:{b:1}}, function(err, doc) {
// I got the read document in the object 'doc'
});
});
});
});
Nun möge ich einen Feldnamen umbenennen, während nur (nicht im DB) abrufen, beispielsweise mit dem obigen Code, ich habe ein Feld b
in dem zurückgegebenen Objekt mit dem Namen doc
ich mag es baseID
sein statt b
Gibt es eine Möglichkeit, es zu tun?
Hinweis: Ich kann keine Aktion für das abgerufene Objekt doc
ausführen, um Feld wie JSON-Schlüsselumbenennung umzubenennen. Ich möchte, dass es abgefragt wird und MongoDB wird das Gleiche tun.
Leider sind nicht alle Treiber haben diese Funktion. Es gibt eine Diskussion [http://stackoverflow.com/questions/14106261/do-any-mongodb-orms-allow-you-to-alias-fields], die immer noch relevant ist. – WiredPrairie