Mongodb自增id實(shí)現(xiàn)方法
本文實(shí)例講述了Mongodb自增id實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
首先創(chuàng)建一個(gè)自動(dòng)增長id集合 ids
>db.ids.save({name:"user", id:0});
可以查看一下是否成功
> db.ids.find(); { "_id" : ObjectId("4c637dbd900f00000000686c"), "name" : "user", "id" : 0 }
然后每次添加新用戶之前自增一下 ids集合 獲得id
然后每次在db.user集合里添加新用戶之前 在db.ids集合中的name="user"文檔的id值加1返回文檔
>userid = db.ids .findAndModify({update:{$inc:{'id':1}}, query:{"name":"user"}, new:true}); { "_id" : ObjectId("4c637dbd900f00000000686c"), "name" : "user", "id" : 1 }
注:因?yàn)閒indAndModify是一個(gè)方法完成更新查找兩個(gè)操作,所以具有原子性,多線程不會(huì)沖突。
然后保存相應(yīng)的數(shù)據(jù)
>db.user .save({uid:userid.id, username:"dotcoo", password:"dotcoo", info:"http://www.dbjr.com.cn/ "}); // --------- update 2011-03-27 13:11 ------------------------
其實(shí)上邊兩行可以寫為一步
>db.user .save({ uid: db.ids .findAndModify({ update:{$inc:{'id':1}}, query:{"name":"user"}, new:true}).id, //讓db.ids集合中的name="user"文檔的id值加1并返回充當(dāng)自增id username: "dotcoo", password:"dotcoo", info:"http://www.dbjr.com.cn/ "}); // --------- update 2011-03-27 13:11 ------------------------
查看結(jié)果
> db.user.find(); { "_id" : ObjectId("4c637f79900f00000000686d"), "uid" : 1, "username" : "admin", "password" : "admin" }
這是mongo的shell,如果用的是服務(wù)器端程序Java php Python,可以自己對這些操作封裝一下,只用傳幾個(gè)參數(shù)就可以返回自增的id,還可以實(shí)現(xiàn)像Oracle的跨表的自增id。
自己寫了一段php的,拿出來給大家分享。
<?php function mid($name, $db){ $update = array('$inc'=>array("id"=>1)); $query = array('name'=>$name); $command = array( 'findandmodify'=>'ids', 'update'=>$update, 'query'=>$query, 'new'=>true, 'upsert'=>true ); $id = $db->command($command); return $id['value']['id']; } $conn = new Mongo(); $db = $conn->idtest; $id = mid('user', $db); $db->user->save(array('uid'=>$id, 'username'=>'kekeles', 'password'=>'kekeles', 'info'=>'http://www.dbjr.com.cn/ ')); $conn->close(); ?>
其具體實(shí)現(xiàn)方式主要是利用MongoDB中findAndModify命令,只要每次往MongoDB里insert對象前生成ID賦值給_id就OK了,因?yàn)樗膶?shí)現(xiàn)滿足原子性,所以不存在并發(fā)問題。
另外說明一點(diǎn),findAndModify本身提供了一個(gè)upsert參數(shù),為true的話可以自動(dòng)insert,但那樣就不能自定義初始值了,所以文中示例沒有使用upsert。
BTW,數(shù)據(jù)庫“_seq”的名字以下劃線開頭,這樣列表的時(shí)候會(huì)排在前面,容易分辨。
希望本文所述對大家MongoDB數(shù)據(jù)庫程序設(shè)計(jì)有所幫助。
相關(guān)文章
MongoDB數(shù)據(jù)庫中索引和explain的使用教程
這篇文章主要給大家介紹了關(guān)于MongoDB數(shù)據(jù)庫中索引和explain使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Mongodb具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08Windows系統(tǒng)安裝運(yùn)行Mongodb服務(wù)
今天小編就為大家分享一篇關(guān)于Windows系統(tǒng)安裝運(yùn)行Mongodb服務(wù),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-10-10MongoDB排序時(shí)內(nèi)存大小限制與創(chuàng)建索引的注意事項(xiàng)詳解
在數(shù)據(jù)量超大的情形下,任何數(shù)據(jù)庫系統(tǒng)在創(chuàng)建索引時(shí)都是一個(gè)耗時(shí)的大工程,下面這篇文章主要給大家介紹了關(guān)于MongoDB排序時(shí)內(nèi)存大小限制與創(chuàng)建索引的注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下2022-05-05MongoDB的$sample、aggregate和$rand實(shí)現(xiàn)隨機(jī)選取數(shù)據(jù)
在MongoDB中,我們可以使用內(nèi)置的$sample聚合操作符來隨機(jī)生成數(shù)據(jù),$sample可以從集合文檔中隨機(jī)選擇指定數(shù)量的文檔,但由于其查詢整個(gè)集合的性能問題,應(yīng)該慎用,aggregate方法以及$rand函數(shù)的結(jié)合使用可以實(shí)現(xiàn)更加靈活的查詢操作,并且可以對查詢結(jié)果進(jìn)行精細(xì)篩選2024-01-01mongodb 添加用戶及權(quán)限設(shè)置詳解
我知道的關(guān)系型數(shù)據(jù)庫都是有權(quán)限控制的,什么用戶能訪問什么庫,什么表,什么用戶可以插入,更新,而有的用戶只有讀取權(quán)限。2014-07-07Mongodb解決不能連接到服務(wù)器的錯(cuò)誤問題
這篇文章主要介紹了Mongodb解決不能連接到服務(wù)器的錯(cuò)誤問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01MongoDB.NET 2.2.4驅(qū)動(dòng)版本對Mongodb3.3數(shù)據(jù)庫中GridFS增刪改查
這篇文章主要為大家詳細(xì)介紹了使用MongoDB.NET 2.2.4驅(qū)動(dòng)版本對Mongodb3.3數(shù)據(jù)庫中GridFS增刪改查,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11cgroup限制mongodb進(jìn)程內(nèi)存大小
這篇文章主要介紹了cgroup限制mongodb進(jìn)程內(nèi)存大小,需要的朋友可以參考下2014-07-07MongoDB實(shí)現(xiàn)基于關(guān)鍵詞的文章檢索功能(C#版)
這篇文章主要介紹了MongoDB實(shí)現(xiàn)基于關(guān)鍵詞的文章檢索功能(C#版)的相關(guān)資料,需要的朋友可以參考下2016-04-04