亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > mongodb字段值自增長實現代碼

mongodb字段值自增長實現代碼

熱門標簽:河南電話外呼系統招商 內蒙古營銷智能外呼系統哪個好 crm外呼系統聯系方式 小裙科技電銷機器人怎樣 智能外呼系統官網 外呼線路資源屬于電信業務嗎 長沙電銷外呼防封卡是什么 呼和浩特外呼系統原理是什么 青白江400企業電話申請

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

1.創建計數器集合

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

{
  "_id":1,
  "title": "標題",
  "content": "內容1",
  "type": "類型"
}

為此,創建 counters 集合,序列字段值可以實現自動長:

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可以對文檔的某個值為數字型(只能為滿足要求的數字)的鍵進行增減的操作;

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

3.測試

創建測試集合sms:

db.createCollection("sms")

在sms集合中新增文檔,實現_id自增長: 

db.sms.insert({
  _id: db.counters.findAndModify({query:{_id: "objId" },update: {$inc:{sequence_value:1}},"new":true}).sequence_value,
  title: "標題1",
  content: "短信1",
  type: "1"
})

查詢sms集合:

db.sms.find({}).sort({_id:1})

4.java實現

java實現以上功能,數據庫驅動版本不同運行效果有差異,僅供參考:

private MongoDatabase conn;
 
static{
  this.conn = getDatabase(databaseName);
}
 
/**
 * 連接數據庫
 * @param databaseName 數據庫名稱
 * @return       數據庫連接對象
 */
private static MongoDatabase getDatabase(databaseName){
  MongoDatabase mongoDatabase = null;
  try{  
    // 連接到 mongodb 服務
    MongoClient mongoClient = new MongoClient( "localhost" , 27017 );
  
    // 連接到數據庫
    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");
    ListDocument> documents = new ArrayListDocument>();
    for(int i = 0; i  20; i++){
      int id = getNextSequenceValue();
      Document document = new Document("_id", id).
      append("title", "標題" + 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");
  FindIterableDocument> findIterable = collection.find(); 
  MongoCursorDocument> mongoCursor = findIterable.iterator(); 
  while(mongoCursor.hasNext()){ 
    System.out.println(mongoCursor.next()); 
  }
}

5.總結

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

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

您可能感興趣的文章:
  • MongoDB進階之動態字段設計詳解
  • pymongo實現控制mongodb中數字字段做加法的方法
  • MongoDB查詢字段沒有創建索引導致的連接超時異常解案例分享
  • MongoDB查詢操作限制返回字段的方法

標簽:呼倫貝爾 白山 楚雄 黃石 池州 菏澤 安順 舟山

巨人網絡通訊聲明:本文標題《mongodb字段值自增長實現代碼》,本文關鍵詞  mongodb,字段,值自,增長,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mongodb字段值自增長實現代碼》相關的同類信息!
  • 本頁收集關于mongodb字段值自增長實現代碼的相關信息資訊供網民參考!
  • 推薦文章
    日韩男人天堂| 国产麻豆精品hdvideoss| 欧美激情一区二区三区视频 | 成人免费一级纶理片| 天天做日日干| 国产美女在线一区二区三区| 精品国产一区二区三区免费| 亚洲 欧美 91| 欧美另类videosbestsex视频 | 久久国产精品自由自在| 日本免费看视频| 美女免费精品视频在线观看| 一本高清在线| 成人免费高清视频| 人人干人人草| 深夜做爰性大片中文| 九九免费高清在线观看视频| 成人影视在线播放| 成人影院久久久久久影院| 久久精品免视看国产明星| 久草免费在线视频| 欧美大片一区| 午夜欧美福利| 日本免费看视频| 日韩在线观看网站| 精品久久久久久综合网| 日本在线www| 精品美女| 日韩一级黄色片| 日本特黄特色aaa大片免费| 日韩在线观看免费完整版视频| 麻豆网站在线免费观看| 人人干人人草| 一级片免费在线观看视频| 国产一区二区精品久| 黄视频网站在线免费观看| 国产伦久视频免费观看 视频| 亚欧乱色一区二区三区| 亚洲女人国产香蕉久久精品 | 91麻豆国产级在线| 天天色成人网| 日本特黄特黄aaaaa大片| 韩国三级视频在线观看| 精品美女| 亚洲第一页乱| a级毛片免费观看网站| 99色视频在线观看| 成人免费观看男女羞羞视频| 韩国三级香港三级日本三级la| 国产韩国精品一区二区三区| 日日夜夜婷婷| 九九精品影院| 欧美a级成人淫片免费看| 天堂网中文字幕| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 亚洲天堂在线播放| 精品在线视频播放| 在线观看导航| 国产a免费观看| 国产成人精品影视| 国产精品自拍亚洲| 91麻豆tv| 999久久狠狠免费精品| 99久久精品国产免费| 你懂的福利视频| 久久99这里只有精品国产| 国产成人精品一区二区视频| 精品国产亚洲一区二区三区| 91麻豆精品国产高清在线| 国产麻豆精品高清在线播放| 999精品影视在线观看| 欧美激情影院| 久久99中文字幕| 国产伦精品一区三区视频| 国产成人精品综合在线| 一级片片| 99色视频在线观看| 四虎影视精品永久免费网站| 九九热精品免费观看| 91麻豆精品国产自产在线观看一区| 国产原创视频在线| 九九精品在线播放| 一a一级片| 日本乱中文字幕系列| 99热精品在线| 91麻豆精品国产自产在线观看一区 | 国产精品自拍一区| 国产原创视频在线| 美国一区二区三区| 四虎久久精品国产| 欧美爱色| 99热热久久| 台湾美女古装一级毛片| 国产成a人片在线观看视频| 免费国产在线观看| 人人干人人插| 精品国产三级a| 精品视频在线看| 你懂的福利视频| a级毛片免费观看网站| 中文字幕一区二区三区 精品| 国产高清在线精品一区a| 国产精品自拍一区| 免费一级生活片| 国产视频一区二区三区四区| 国产美女在线一区二区三区| 欧美激情中文字幕一区二区| a级毛片免费全部播放| 国产极品精频在线观看| 青青青草影院| 日本免费看视频| 日日夜夜婷婷| 91麻豆精品国产自产在线观看一区| 99色吧| 精品视频免费在线| 国产成人精品一区二区视频| 午夜在线亚洲男人午在线| 九九九在线视频| 精品国产一区二区三区久久久蜜臀 | 日韩男人天堂| 欧美a免费| 国产麻豆精品hdvideoss| 亚洲精品影院一区二区| 久久精品免视看国产成人2021| 色综合久久天天综合绕观看| 日本在线不卡视频| 精品视频在线观看一区二区三区| 欧美电影免费| 精品在线视频播放| 色综合久久手机在线| 国产成人啪精品| 亚洲女初尝黑人巨高清在线观看| 亚洲 国产精品 日韩| 99色视频在线观看| 国产国语在线播放视频| 成人免费高清视频| 成人免费福利片在线观看| 色综合久久天天综合绕观看| 色综合久久手机在线| a级毛片免费观看网站| 四虎影视库国产精品一区| 色综合久久手机在线| 日韩男人天堂| 国产91精品系列在线观看| 欧美国产日韩精品| 一级毛片视频播放| 国产91视频网| 国产原创中文字幕| 91麻豆国产级在线| 国产视频一区二区三区四区| 国产亚洲免费观看| 日韩一级精品视频在线观看| 日韩在线观看视频免费| 久久精品欧美一区二区| 日韩免费在线观看视频| 色综合久久天天综线观看| 日韩中文字幕一区| 欧美爱爱动态| 亚洲 国产精品 日韩| 一级毛片视频播放| 日本免费区| 欧美大片a一级毛片视频| 人人干人人草| 亚欧成人乱码一区二区| 99久久精品国产高清一区二区 | 国产不卡高清在线观看视频| 亚州视频一区二区| 沈樵在线观看福利| 精品久久久久久影院免费| 日韩专区亚洲综合久久| 国产成人啪精品| 成人影院一区二区三区| 国产一区二区高清视频| 欧美爱爱动态| 亚洲第一页乱| 国产高清在线精品一区二区 | 国产91素人搭讪系列天堂| 日韩一级黄色| 亚久久伊人精品青青草原2020| 青青久久精品国产免费看| 高清一级片| 成人高清免费| 日本在线www| 欧美a级大片| 日韩中文字幕一区二区不卡| 97视频免费在线| 毛片的网站| 精品视频在线观看视频免费视频 | 99色视频在线观看| 精品久久久久久中文字幕一区| 黄视频网站在线免费观看| 亚洲 男人 天堂| 韩国三级香港三级日本三级| 一级女性全黄生活片免费| 九九久久99| 久久国产影院| 国产福利免费视频| 日日日夜夜操| 国产精品123| 国产91丝袜在线播放0|