mongodb实现主键自增

转自: https://blog.csdn.net/miyatang/article/details/19486797 

像mysql中可以自动生成自增长主键id,mongdb中也可以通过js函数实现,

函数 getNextSequence 生成序列号,官方方法:
建立一张表,记录某一个表的_ID 当前值。后面调用此函数生成下一个序列号,
在js 函数如下:
 function getNextSequence(name) {
  var ret = db.counters.findAndModify(
     {
    query: { _id: name },
    update: { $inc: { seq: 1 } },
     new: true
     }
  );
  
   return ret.seq;
  }

直接调用,没有问题
> getNextSequence("userid");
17

退出后,再进来,此函数不见了,是没有保存吗?那前面的定义只是临时的???
这点没明白。如果是此时没有保存,其存在的方法有什么意义?这点还真是和其它数据库区别很大。


> exit
bye
[root@localhost bin]# ./mongo-start.sh
MongoDB shell version: 2.5.5
connecting to: 127.0.0.1:28001/test
Server has startup warnings:
2014-02-19T10:00:20.412+0800 [initandlisten]
2014-02-19T10:00:20.412+0800 [initandlisten] ** NOTE: This is a development version (2.5.5) of MongoDB.
2014-02-19T10:00:20.412+0800 [initandlisten] **       Not recommended for production.
2014-02-19T10:00:20.413+0800 [initandlisten]
> getNextSequence("userid");
2014-02-19T14:11:10.499+0800 ReferenceError: getNextSequence is not defined


再用 保存到DB.SYSTEM.JS 的方式保存自定义函数(或叫存储过程):

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


但再使用同前面的调用 方式无效了。

> getNextSequenct("userid");
2014-02-19T14:21:03.912+0800 ReferenceError: getNextSequenct is not defined
>


虽然查到以下方法进行调用,但感觉很是怪。

> db.eval('getNextSequence("userid")');
18
> db.testdb.insert({_id:db.eval('getNextSequence("userid")')});
SingleWriteResult({
        "writeErrors" : [ ],
        "writeConcernErrors" : [ ],
        "nInserted" : 1,
        "nUpserted" : 0,
        "nUpdated" : 0,
        "nModified" : 0,
        "nRemoved" : 0,
        "upserted" : [ ]
})
> db.testdb.find();
{ "_id" : 19 }

posted @ 2018-09-20 16:11  北极白开水  阅读(2785)  评论(0编辑  收藏  举报