Как автоматически добавлять идентификаторы и публиковать в mongodb, используя узел js - PullRequest
0 голосов
/ 29 августа 2018

Я хочу автоматически увеличивать id в mongoDB при публикации данных. Я могу прикрепить дату для req.body. Как прикрепить идентификаторы с автоинкрементом?

Это мой почтовый звонок:

router.post('/addVisualization', function (req, res, next) {
    MongoClient.connect(url, function (err, db) {
        if (err) throw err;
        var dbo = db.db(dbName);
        req.body.dateOfEntry = new Date();
         function getNextSequence(id) {
            var ret = db.counters.findAndModify(
            {
              query: { _id: id },
              update: { $inc: { seq: 1 } },
              new: true
            }
            );
             return ret.seq;
          }
          dbo.collection("visualization").insertOne(req.body, function (err, resDB) {
            if (err) {
                throw err;
                res.status(401);
                res.send({
                    "status": 401,
                    "message": "Some error happened"
                });
            }
            else {
                console.log("1 document inserted");
                res.status(201)
                res.send({
                    "body": req.body,
                    "status": 201,
                    "message": "visualization has been added"
                });
            }
        });
        db.close();
    });
});

Ответы [ 3 ]

0 голосов
/ 29 августа 2018

Используйте отдельную коллекцию counters для отслеживания последнего идентификатора последовательности.

db.counters.insert(
   {
      _id: "userid",
      seq: 0
   }
)
db.counters.insert(
   {
      _id: "productid",
      seq: 0
   }
)

Создать функцию getNextSequence, которая принимает имя последовательности.

function getNextSequence(name) {
   var ret = db.counters.findAndModify(
          {
            query: { _id: name },
            update: { $inc: { seq: 1 } },
            new: true,
            upsert : true // Creates a new document if no documents match the query
          }
   );

   return ret.seq;
}

Используйте эту функцию getNextSequence() во время insert.

db.users.insert(
   {
     _id: getNextSequence("userid"),
     name: "Mr. X",
     // ... more fields
   }
)

db.products.insert(
   {
     _id: getNextSequence("productid"),
     name: "Mr. Y",
     // ... more fields
   }
)
0 голосов
/ 06 сентября 2018

Попробуйте приведенный ниже код для автоматического увеличения идентификаторов в mongoDB.

router.post('/addVisualization', function (req, res, next) {
  MongoClient.connect(url, {
  useNewUrlParser: true
  }, function (err, db) {
  if (err) throw err;
  var dbo = db.db(dbName);
  req.body.dateOfEntry = new Date();
  req.body.isDeleted = "false";
  var countRow;
  var sequenceDocument = dbo.collection("counterVisualization").findOneAndUpdate({
  _id: "tid"
  }, {
  $inc: {
  sequence_value: 1
  }
  }, {
  new: true
  });
  dbo.collection("counterVisualization").find({
  _id: "tid"
  }).toArray(function (err, result1) {
  if (err) {
  throw err;
  } else {
  countRow = result1[0].sequence_value;
  req.body["_id"] = countRow;    
  dbo.collection("visualization").insertOne(req.body, function (err, resDB) {
  if (err) {
  throw err;
  res.status(401);
  res.send({
  "status": 401,
  "message": "Some error happened"
  });
  } else {
  console.log("1 document inserted");
  res.status(201)
  res.send({
  "body": req.body,
  "status": 201,
  "message": "visualization has been added"
  });
  }
  });
  }
  });
  });
});
0 голосов
/ 29 августа 2018

В mongo db у вас нет идентификаторов автоинкремента, таких как mysql или oracle. Пожалуйста, ознакомьтесь с этим руководством , чтобы узнать, как это сделать из коробки.

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