mongodb id自增问题
迷茫
迷茫 2017-04-22 08:56:12
0
1
561

http://docs.mongodb.org/manual/tutorial/create-an-auto-incrementing-field/
官方文档给出了2种解决方法,我只看了第一种的时候:

function getNextSequence(name) {
   var ret = db.counters.findAndModify(
          {
            query: { _id: name },
            update: { $inc: { seq: 1 } },
            new: true
          }
   );

   return ret.seq;
}

function getNextSequence(name) {
   var ret = db.counters.findAndModify(
          {
            query: { _id: name },
            update: { $inc: { seq: 1 } },
            new: true,
            upsert: true
          }
   );

   return ret.seq;
}

英文看得有点模糊,多了一个upsert到底是好还是不好?

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回复(1)
黄舟

不好,除非你有唯一索引,否则可能插入多个相同名字的文档。可能会有多个 findAndModify 函数同时运行,它们都发现找不到已有的文档,于是都决定插入新文档,于是就重复了。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板