node.js mongodb выбрать документ по _id node-mongodb-native - PullRequest
77 голосов
/ 04 февраля 2011

Я пытаюсь выбрать документ по идентификатору

Я пробовал:

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?

Ответы [ 7 ]

120 голосов
/ 04 марта 2011
var mongo = require('mongodb');
var o_id = new mongo.ObjectID(theidID);
collection.update({'_id': o_id});
66 голосов
/ 27 января 2013

Это подход, который работал для меня.

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);
    });
  });
}
17 голосов
/ 17 июля 2014

теперь вы можете просто использовать это:

var ObjectID = require('mongodb').ObjectID;
var o_id = new ObjectID("yourObjectIdString");
....
collection.update({'_id': o_id});

Документацию можно посмотреть здесь

11 голосов
/ 08 марта 2011

С 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);
5 голосов
/ 06 января 2018

Я только что использовал этот код в приложении Node.js.bcrypt с «presave», убедитесь, что вы не будете шифровать пароль после каждой модификации записи в БД.

0 голосов
/ 16 ноября 2018

Вот что у меня сработало.Использование mongoDB

const mongoDB = require('mongodb')

Затем внизу, где я делаю экспресс-вызов.

router.get('/users/:id', (req, res) => {
const id = req.params.id;
var o_id = new mongoDB.ObjectID(id);

const usersCollection = database.collection('users');

usersCollection.findOne({
  _id: o_id
})

.then(userFound => {
  if (!userFound){
    return res.status(404).end();
  }
  // console.log(json(userFound));
  return res.status(200).json(userFound)
})
.catch(err => console.log(err));

 });`
0 голосов
/ 14 августа 2013

Ответ зависит от типа переменной, которую вы передаете в качестве идентификатора. Я получил идентификатор объекта, выполнив запрос и сохранив свой account_id в качестве атрибута ._id. Используя этот метод, вы просто делаете запрос, используя идентификатор Монго.

// 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();    
        } 
      }
    )  
  } 
})

});

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...