узел.Яш выберите документ в MongoDB с помощью идентификатора узла-в MongoDB-родной
Я пытаюсь выбрать документ по id
Я пробовал:
collection.update({ "_id": { "$oid": + theidID } }
collection.update({ "_id": theidID }
collection.update({ "_id.$oid": theidID }}
тоже пробовал:
collection.update({ _id: new ObjectID(theidID ) }
Это дает мне ошибку 500...
var mongo = require('mongodb')
var BSON = mongo.BSONPure;
var o_id = new BSON.ObjectID(theidID );
collection.update({ _id: o_id }
ни один из них не работает. Как выбрать по _id?
6 ответов:
var mongo = require('mongodb'); var o_id = new mongo.ObjectID(theidID); collection.update({'_id': o_id});
этот подход, который работал для меня.
var ObjectId = require('mongodb').ObjectID; var get_by_id = function(id, callback) { console.log("find by: "+ id); get_collection(function(collection) { collection.findOne({"_id": new ObjectId(id)}, function(err, doc) { callback(doc); }); }); }
вы можете просто использовать это:
var ObjectID = require('mongodb').ObjectID; var o_id = new ObjectID("yourObjectIdString"); .... collection.update({'_id': o_id});
вы можете посмотреть документацию здесь
С
native_parser:false
:var BSON = require('mongodb').BSONPure; var o_id = BSON.ObjectID.createFromHexString(theidID);
С
native_parser:true
:var BSON = require('mongodb').BSONNative; var o_id = BSON.ObjectID.createFromHexString(theidID);
Я просто использовал этот код в узел.js приложение в файле контроллера, и он работает:
var ObjectId = require('mongodb').ObjectId; ... User.findOne({_id:ObjectId("5abf2eaa1068113f1e")}) .exec(function(err,data){ // do stuff })
Не забудьте установить "mongodb" раньше, и если вы используете шифрование ваших паролей с помощью bcrypt с "presave", убедитесь, что вы не будете шифровать пароль после каждой модификации записи в БД.
ответ зависит от типа переменной, которую вы передаете в качестве идентификатора. Я вытащил идентификатор объекта, выполнив запрос и сохранив свой account_id в качестве._атрибут id. Используя этот метод, вы просто запрашиваете с помощью идентификатора mongo.
// begin account-manager.js var MongoDB = require('mongodb').Db; var dbPort = 27017; var dbHost = '127.0.0.1'; var dbName = 'sample_db'; db = new MongoDB(dbName, new Server(dbHost, dbPort, {auto_reconnect: true}), {w: 1}); var accounts = db.collection('accounts'); exports.getAccountById = function(id, callback) { accounts.findOne({_id: id}, function(e, res) { if (e) { callback(e) } else { callback(null, res) } }); } // end account-manager.js // my test file var AM = require('../app/server/modules/account-manager'); it("should find an account by id", function(done) { AM.getAllRecords(function(error, allRecords){ console.log(error,'error') if(error === null) { console.log(allRecords[0]._id) // console.log('error is null',"record one id", allRecords[0]._id) AM.getAccountById( allRecords[0]._id, function(e,response){ console.log(response,"response") if(response) { console.log("testing " + allRecords[0].name + " is equal to " + response.name) expect(response.name).toEqual(allRecords[0].name); done(); } } ) } })
});