1. 程式人生 > >mogodb 的自定義函式定義及引用

mogodb 的自定義函式定義及引用

在學習MONGODB 遇到以下問題:


函式 getNextSequence 生成序列號,官方方法:
建立一張表,記錄某一個表的_ID 當前值。後面呼叫此函式生成下一個序列號,
在測試此函式時,遇到以下問題:
(url:http://docs.mongodb.org/manual/t ... incrementing-field/)


> 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
[
[email protected]
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 }
>