日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

MongoDB学习笔记一ID自增长

發布時間:2024/9/20 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MongoDB学习笔记一ID自增长 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概要

MongoDB 的_id字段作為一個主鍵存在于所有文檔的最頂層,_id必須是唯一的,而且總是具有唯一約束的索引。除了唯一約束,你可以在集合中的_id字段上使用任何值,

以下這個指南描述了在_id上創建一個自增序列的兩種方式:

Use Counter Collection

Optimistic Loop

注意事項

一般情況下,你不會愿意在_id字段,或任何字段上使用自增模式,那是因為不會有大量的文檔構成的大規模數據庫,通常情況下,更為理想的是默認_id。

實現過程

Use Counter Collection

Counter集合實現:

利用一個單獨的計數器集合去跟蹤我們使用的最后一個數字序列。該_id字段包含了序列名稱和序列字段中該序列最后的值。

1、插入計數器集合,設置初始值為userid:

?
1 2 3 4 5 6 db.counters.insert( ???{ ??????_id:?"userid", ??????seq: 0 ???} )
2、創建一個getNextSequence函數,參數為序列的name,函數使用findandmodify()方法去自動增長序列的值并返回增長之后的結果: ?
1 2 3 4 5 6 7 8 9 10 11 functiongetNextSequence(name) { ???var ret = db.counters.findAndModify( ??????????{ ????????????query: { _id:?name}, ????????????update: { $inc: { seq: 1 } }, ????????????new:?true ??????????} ???); ???returnret.seq; }
3、在接下來插入數據的時候,使用getNextSequence這個函數: ?
1 2 3 4 5 6 7 8 9 10 11 12 db.users.insert( ???{ ?????_id: getNextSequence("userid"),//注意getNextSequence參數要與計數器集合中_id值一致 ?????name:?"Sarah C." ???} ) db.users.insert( ???{ ?????_id: getNextSequence("userid"), ?????name:?"Bob D." ???} )
4、你可以試著查看結果: ?
1 db.users.find()
5、_id字段包含了自動增長序列的值: ?
1 2 3 4 5 6 7 8 { ??_id : 1, ??name:?"Sarah C." } { ??_id : 2, ??name:?"Bob D." }
findandmodify這個方法包含了更新,查詢字段并不是一定要有唯一索引,該方法可以在某些情況下多次插入同一個文檔。例如,有多個客戶端在使用同樣查詢條件時,

都調用該方法,那么調用這些方法在執行更新操作之前必須先完成查詢操作,而且這些方法能插入相同的文檔。

在計數器事例中,查詢字段是_id字段,它總是有一個獨立的索引。我們再看如下示例:

?
1 2 3 4 5 6 7 8 9 10 11 functiongetNextSequence(name) { ???var ret = db.counters.findAndModify( ??????????{ ????????????query: { _id:?name}, ????????????update: { $inc: { seq: 1 } }, ????????????new:?true, ????????????upsert:?true ??????????} ???); ???returnret.seq; }
如果多個客戶端在傳入相同參數情況下來調用getNextSequence()方法,然后我們會發現以下其中一個行為將會發生:

一次findandmodify()方法將會成功插入一條文檔;

0個或多個findandmodify()方法將會更新新插入的文件;

當它們試圖插入重復的數據時,0個或多個findandmodify()方法;

如果由于違反了唯一約束而導致方法失敗,請重試。

Optimistic Loop

略。


來源:http://blog.csdn.net/younger_z/article/details/53484779

總結

以上是生活随笔為你收集整理的MongoDB学习笔记一ID自增长的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。