mongodb字段值自增長(zhǎng)實(shí)現(xiàn)代碼
MongoDB 沒有像 SQL 一樣有自動(dòng)增長(zhǎng)的功能, MongoDB 的 _id 是系統(tǒng)自動(dòng)生成的12字節(jié)唯一標(biāo)識(shí)。但在某些情況下,我們可能需要實(shí)現(xiàn) ObjectId 自動(dòng)增長(zhǎng)功能。由于 MongoDB 沒有實(shí)現(xiàn)這個(gè)功能,我們可以通過(guò)編程的方式來(lái)實(shí)現(xiàn),以下我們將在 counters 集合中實(shí)現(xiàn)_id字段自動(dòng)增長(zhǎng)。
1.創(chuàng)建計(jì)數(shù)器集合
期望_id字段從1,2,3,4到n,啟動(dòng)一個(gè)自動(dòng)遞增的整數(shù)序列,如:
{ "_id":1, "title": "標(biāo)題", "content": "內(nèi)容1", "type": "類型" }
為此,創(chuàng)建 counters 集合,序列字段值可以實(shí)現(xiàn)自動(dòng)長(zhǎng):
db.createCollection("counters")
初始化集合,以objId作為主鍵,sequence_value 字段是序列通過(guò)自動(dòng)增長(zhǎng)后的一個(gè)值:
db.counters.insert({_id:"objId",sequence_value:0})
2.查詢序列號(hào)
查詢返回更新后的序列號(hào)
db.counters.findAndModify({ query: {_id: "objId" }, update: {$inc:{sequence_value:1}}, new: true }).sequence_value;
操作符解釋:
$inc可以對(duì)文檔的某個(gè)值為數(shù)字型(只能為滿足要求的數(shù)字)的鍵進(jìn)行增減的操作;
db.collection.findAndModify({ query: <document>, //定義關(guān)于哪些記錄需要修改的選擇標(biāo)準(zhǔn) sort: <document>, //確定選擇標(biāo)準(zhǔn)檢索多個(gè)文檔時(shí)應(yīng)修改的文檔 new: <boolean>, //表示將顯示修改后的文檔 fields: <document>, //指定要返回的字段集 upsert: <boolean> //如果選擇標(biāo)準(zhǔn)無(wú)法檢索文檔,則創(chuàng)建一個(gè)新文檔 remove: <boolean> //為true,query指定的文檔將從數(shù)據(jù)庫(kù)中刪除 )}
3.測(cè)試
創(chuàng)建測(cè)試集合sms:
db.createCollection("sms")
在sms集合中新增文檔,實(shí)現(xiàn)_id自增長(zhǎng):
db.sms.insert({ _id: db.counters.findAndModify({query:{_id: "objId" },update: {$inc:{sequence_value:1}},"new":true}).sequence_value, title: "標(biāo)題1", content: "短信1", type: "1" })
查詢sms集合:
db.sms.find({}).sort({_id:1})
4.java實(shí)現(xiàn)
java實(shí)現(xiàn)以上功能,數(shù)據(jù)庫(kù)驅(qū)動(dòng)版本不同運(yùn)行效果有差異,僅供參考:
private MongoDatabase conn; static{ this.conn = getDatabase(databaseName); } /** * 連接數(shù)據(jù)庫(kù) * @param databaseName 數(shù)據(jù)庫(kù)名稱 * @return 數(shù)據(jù)庫(kù)連接對(duì)象 */ private static MongoDatabase getDatabase(databaseName){ MongoDatabase mongoDatabase = null; try{ // 連接到 mongodb 服務(wù) MongoClient mongoClient = new MongoClient( "localhost" , 27017 ); // 連接到數(shù)據(jù)庫(kù) MongoDatabase mongoDatabase = mongoClient.getDatabase(databaseName); System.out.println("Connect to database successfully"); }catch(Exception e){ System.err.println( e.getClass().getName() + ": " + e.getMessage() ); } return mongoDatabase; } /** * 獲取最新序列號(hào) * @return 序列號(hào) */ private static int getNextSequenceValue(){ DBCollection collection = conn.getCollection("counters"); DBObject query = new BasicDBObject("_id", new BasicDBObject("$eq", "objId")); DBObject newDocument =new BasicDBObject(); newDocument.put("$inc", new BasicDBObject().append("sequence_value", 1)); newDocument.put("new": true); DBObject ret = collection.findAndModify(query, newDocument); if (ret == null){ return 0; }else{ return (Integer)ret.get("sequence_value"); } } /** * 新增集合文檔 */ public static void addSms(){ int id = getNextSequenceValue(); if(id != 0){ DBCollection collection = conn.getCollection("sms"); List<Document> documents = new ArrayList<Document>(); for(int i = 0; i < 20; i++){ int id = getNextSequenceValue(); Document document = new Document("_id", id). append("title", "標(biāo)題" + i). append("content", "短信" + i). append("type", 1); documents.add(document); } collection.insertMany(documents); System.out.println("文檔插入成功"); } } /** * 查詢集合 */ public static void findSms(){ DBCollection collection = conn.getCollection("sms"); FindIterable<Document> findIterable = collection.find(); MongoCursor<Document> mongoCursor = findIterable.iterator(); while(mongoCursor.hasNext()){ System.out.println(mongoCursor.next()); } }
5.總結(jié)
有了字段自增長(zhǎng)功能,可以實(shí)現(xiàn)訂單流水號(hào)、編碼的流水號(hào)等功能,可以實(shí)現(xiàn)同MySQL自增字段、Oracle序列的相同效果。
到此這篇關(guān)于mongodb字段值自增長(zhǎng)實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)mongodb字段值自增長(zhǎng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MongoDB單表數(shù)據(jù)的導(dǎo)出和恢復(fù)實(shí)例講解
MongoDB 是一個(gè)跨平臺(tái)的,面向文檔的數(shù)據(jù)庫(kù),提供高性能,高可用性和可擴(kuò)展性方便。 MongoDB 工作在收集和文件的概念。接下來(lái)通過(guò)本文給大家介紹MongoDB單表數(shù)據(jù)的導(dǎo)出和恢復(fù)實(shí)例講解,對(duì)mongodb導(dǎo)出和恢復(fù)數(shù)據(jù)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-03-03Mongodb 3.2.9開啟用戶權(quán)限認(rèn)證問(wèn)題的步驟詳解
這篇文章主要給大家介紹了關(guān)于Mongodb 3.2.9開啟用戶權(quán)限認(rèn)證問(wèn)題的詳細(xì)步驟,通過(guò)開啟權(quán)限認(rèn)證,會(huì)對(duì)大家的Mongodb更加保護(hù)的安全些,文中將步驟介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-08-08mongodb安裝_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了mongodb安裝,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08Win10 安裝 MongoDB 3.6.5 失敗的問(wèn)題及解決方法
這篇文章主要介紹了Win10 安裝 MongoDB 3.6.5 失敗的問(wèn)題及解決方法,需要的朋友可以參考下2018-05-05MongoDB服務(wù)端JavaScript腳本使用方法
這篇文章主要介紹了MongoDB服務(wù)端JavaScript腳本使用方法,需要的朋友可以參考下2015-10-10MongoDB的安裝啟動(dòng)及做成windows服務(wù)的教程圖解
這篇文章主要介紹了MongoDB的安裝啟動(dòng)及做成windows服務(wù)的教程圖解,非常不錯(cuò),具有一定的參考借鑒價(jià)值,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧2018-05-05MongoDB系列教程(三):Windows中下載和安裝MongoDB
這篇文章主要介紹了MongoDB系列教程(三):MongoDB下載和安裝,本文講解使用Windows環(huán)境安裝MongoDB,需要的朋友可以參考下2015-05-05