日韩性视频-久久久蜜桃-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自增长的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 亚洲欧美综合网 | 乱视频在线观看 | 天堂成人av | 中文字幕日韩一区二区 | 久久综合丁香 | 天天拍夜夜拍 | 蜜桃臀aⅴ精品一区二区三区 | 婷婷综合在线观看 | 日日热 | 欧美a图 | 欧美日韩一级片在线观看 | jizzjizz日本免费视频 | 91精品国 | 欧美视频亚洲视频 | 97人妻一区二区精品视频 | 亚洲成熟少妇视频在线观看 | 操日韩| www.天天干 | 黄色片一区二区三区 | 欧美一级在线播放 | bt天堂av | 孕妇疯狂做爰xxxⅹ 国产精品乱码久久久久久 99久久久成人国产精品 | 亚洲综合视频网站 | 澳门黄色网 | 激情视频网 | 国产第一网站 | 歪歪视频在线观看 | 偷拍综合网 | 中国女人高潮hd | 欧美色88| 69av在线视频| 亚洲私人网站 | 麻豆av一区二区三区 | 日本一区二区三区视频在线播放 | 在线看黄色片 | 欧美偷拍亚洲 | 好男人.www | 蜜臀久久久久久999 大陆熟妇丰满多毛xxxⅹ | 高清欧美性猛交xxxx黑人猛交 | 一级欧美一级日韩 | 婷婷导航 | 都市激情av | 日本高清有码 | 欧美男人天堂 | 少妇被又大又粗又爽毛片久久黑人 | 国产一区二区视频在线观看免费 | 亚洲青春草 | 手机在线看片国产 | 91艹 | 久久久久亚洲av片无码v | 国产一区激情 | 色综合久久88| 三女警花合力承欢猎艳都市h | 色黄视频| 久久综合资源 | 熟妇高潮一区二区高潮 | 精品国产91久久久久久久妲己 | 亚洲色图综合网 | 50度灰在线 | 欧美天天爽 | 久久天天躁狠狠躁夜夜躁 | 亚洲最新偷拍 | 国内精品久久久久久久久 | 色多多黄色 | 一卡二卡久久 | 欧美久久激情 | va毛片 | 亚洲美女爱爱 | 十大污网站 | 日产毛片 | 国产一区二区三区欧美 | 日本wwww色 | 日本免费在线播放 | 欧洲av在线播放 | 精品成人一区二区 | 亚洲精品电影在线观看 | 亚洲一区二区三区四区 | 91女神在线 | 伊人网av在线 | 国产精品免费av一区二区三区 | 中文字幕丰满乱子伦无码专区 | 国产视频一区二区在线播放 | 亚洲综合第一区 | 日韩三区四区 | 国产精品久久久久久久久久免费看 | 日韩七区 | 在线看片日韩 | 红桃一区二区三区 | 一女双乳被两男吸视频 | 天天色天天草 | 日韩欧美一区二区三区免费观看 | 一级高清视频 | 一区二区三区视频免费视 | 桃色视频在线 | 亚洲人成色777777精品音频 | 亚洲精品一区二区三 | 日本免费电影一区二区三区 | 天天毛片 | 久热伊人 |