欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mongodb字段值自增長實現(xiàn)代碼

 更新時間:2021年01月15日 08:26:41   作者:zxw08611  
這篇文章主要介紹了mongodb字段值自增長實現(xiàn),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

MongoDB 沒有像 SQL 一樣有自動增長的功能, MongoDB 的 _id 是系統(tǒng)自動生成的12字節(jié)唯一標(biāo)識。但在某些情況下,我們可能需要實現(xiàn) ObjectId 自動增長功能。由于 MongoDB 沒有實現(xiàn)這個功能,我們可以通過編程的方式來實現(xiàn),以下我們將在 counters 集合中實現(xiàn)_id字段自動增長。

1.創(chuàng)建計數(shù)器集合

期望_id字段從1,2,3,4到n,啟動一個自動遞增的整數(shù)序列,如:

{
  "_id":1,
  "title": "標(biāo)題",
  "content": "內(nèi)容1",
  "type": "類型"
}

為此,創(chuàng)建 counters 集合,序列字段值可以實現(xiàn)自動長:

db.createCollection("counters")

初始化集合,以objId作為主鍵,sequence_value 字段是序列通過自動增長后的一個值:

db.counters.insert({_id:"objId",sequence_value:0})

2.查詢序列號

查詢返回更新后的序列號

db.counters.findAndModify({
  query: {_id: "objId" },
  update: {$inc:{sequence_value:1}},
  new: true
}).sequence_value;

操作符解釋:

$inc可以對文檔的某個值為數(shù)字型(只能為滿足要求的數(shù)字)的鍵進(jìn)行增減的操作;

db.collection.findAndModify({
  query: <document>, //定義關(guān)于哪些記錄需要修改的選擇標(biāo)準(zhǔn)
  sort: <document>, //確定選擇標(biāo)準(zhǔn)檢索多個文檔時應(yīng)修改的文檔
  new: <boolean>, //表示將顯示修改后的文檔
  fields: <document>, //指定要返回的字段集
  upsert: <boolean> //如果選擇標(biāo)準(zhǔn)無法檢索文檔,則創(chuàng)建一個新文檔
  remove: <boolean> //為true,query指定的文檔將從數(shù)據(jù)庫中刪除
)}

3.測試

創(chuàng)建測試集合sms:

db.createCollection("sms")

在sms集合中新增文檔,實現(xiàn)_id自增長: 

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實現(xiàn)

java實現(xiàn)以上功能,數(shù)據(jù)庫驅(qū)動版本不同運行效果有差異,僅供參考:

private MongoDatabase conn;
 
static{
  this.conn = getDatabase(databaseName);
}
 
/**
 * 連接數(shù)據(jù)庫
 * @param databaseName 數(shù)據(jù)庫名稱
 * @return       數(shù)據(jù)庫連接對象
 */
private static MongoDatabase getDatabase(databaseName){
  MongoDatabase mongoDatabase = null;
  try{  
    // 連接到 mongodb 服務(wù)
    MongoClient mongoClient = new MongoClient( "localhost" , 27017 );
  
    // 連接到數(shù)據(jù)庫
    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;
}
 
/**
 * 獲取最新序列號
 * @return 序列號
 */
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é)

有了字段自增長功能,可以實現(xiàn)訂單流水號、編碼的流水號等功能,可以實現(xiàn)同MySQL自增字段、Oracle序列的相同效果。

到此這篇關(guān)于mongodb字段值自增長實現(xiàn)的文章就介紹到這了,更多相關(guān)mongodb字段值自增長內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MongoDB單表數(shù)據(jù)的導(dǎo)出和恢復(fù)實例講解

    MongoDB單表數(shù)據(jù)的導(dǎo)出和恢復(fù)實例講解

    MongoDB 是一個跨平臺的,面向文檔的數(shù)據(jù)庫,提供高性能,高可用性和可擴展性方便。 MongoDB 工作在收集和文件的概念。接下來通過本文給大家介紹MongoDB單表數(shù)據(jù)的導(dǎo)出和恢復(fù)實例講解,對mongodb導(dǎo)出和恢復(fù)數(shù)據(jù)知識感興趣的朋友一起學(xué)習(xí)吧
    2016-03-03
  • Mongodb 3.2.9開啟用戶權(quán)限認(rèn)證問題的步驟詳解

    Mongodb 3.2.9開啟用戶權(quán)限認(rèn)證問題的步驟詳解

    這篇文章主要給大家介紹了關(guān)于Mongodb 3.2.9開啟用戶權(quán)限認(rèn)證問題的詳細(xì)步驟,通過開啟權(quán)限認(rèn)證,會對大家的Mongodb更加保護的安全些,文中將步驟介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-08-08
  • mongodb安裝_動力節(jié)點Java學(xué)院整理

    mongodb安裝_動力節(jié)點Java學(xué)院整理

    這篇文章主要介紹了mongodb安裝,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Mongodb常用的身份驗證方式

    Mongodb常用的身份驗證方式

    對MongoDB部署啟用訪問控制會強制執(zhí)行用戶身份驗證,要求在登錄MongoDB系統(tǒng)用戶識別自己。 當(dāng)訪問啟用了訪問控制的MongoDB部署時,用戶只能執(zhí)行由其角色確定的操作。
    2017-08-08
  • Win10 安裝 MongoDB 3.6.5 失敗的問題及解決方法

    Win10 安裝 MongoDB 3.6.5 失敗的問題及解決方法

    這篇文章主要介紹了Win10 安裝 MongoDB 3.6.5 失敗的問題及解決方法,需要的朋友可以參考下
    2018-05-05
  • 淺談MongoDB內(nèi)部的存儲原理

    淺談MongoDB內(nèi)部的存儲原理

    這篇文章主要介紹了淺談MongoDB內(nèi)部的存儲原理,MongoDB是一個面向文檔的數(shù)據(jù)庫系統(tǒng)。使用C++編寫,不支持SQL,但有自己功能強大的查詢語法,需要的朋友可以參考下
    2023-07-07
  • Windows 10下安裝最新版MongoDB的完整步驟

    Windows 10下安裝最新版MongoDB的完整步驟

    這篇文章主要給大家介紹了關(guān)于在Windows 10下安裝最新版MongoDB的完整步驟,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-10-10
  • MongoDB服務(wù)端JavaScript腳本使用方法

    MongoDB服務(wù)端JavaScript腳本使用方法

    這篇文章主要介紹了MongoDB服務(wù)端JavaScript腳本使用方法,需要的朋友可以參考下
    2015-10-10
  • MongoDB的安裝啟動及做成windows服務(wù)的教程圖解

    MongoDB的安裝啟動及做成windows服務(wù)的教程圖解

    這篇文章主要介紹了MongoDB的安裝啟動及做成windows服務(wù)的教程圖解,非常不錯,具有一定的參考借鑒價值,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • MongoDB系列教程(三):Windows中下載和安裝MongoDB

    MongoDB系列教程(三):Windows中下載和安裝MongoDB

    這篇文章主要介紹了MongoDB系列教程(三):MongoDB下載和安裝,本文講解使用Windows環(huán)境安裝MongoDB,需要的朋友可以參考下
    2015-05-05

最新評論