ローカルの MongoDB サーバーからデータをフェッチするために使用している次のコードを考えてみましょう。
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'
});
});
});
});
ここで、(DB ではなく) 取得のみでフィールド名の名前を変更したいと考えています。たとえば、上記のコードではb
、返されたオブジェクトdoc
に名前が付けられたフィールドがbaseID
あり、b
それを行う方法はありますか?
注: 取得したオブジェクトdoc
に対して、JSON キーの名前変更のようにフィールドの名前を変更するアクションを実行することはできません。クエリを実行したいのですが、MongoDB も同じです。