Python+MongoDB自增索引值的簡單實現_python

來源:互聯網
上載者:User

背景

最近在寫一個測試載入器箱,裡面有一個bug記錄系統,因為後台我是用Django和MongoDB來實現的,就遇到了一個問題,要如何?一個自增的欄位。

傳統的關係型資料庫要實現起來是非常容易,只要直接設定一個自增欄位就行了,插入資料時不用管這個索引值,只管自己處理的資料就行了,會自動實現自增的功能,但是非關係型資料庫好像沒有這個功能(或者我不知道)。百度之後發現都是MongoDB的設定方法,並不是我想要的。

解決思路

百度沒有找到好的思路,那就只能自己解決了,我的想法很簡單,欄位不會自增,那麼就自己造一個自增的方案。

我發現在MongoDB修改的方法有一個$inc的方法.可以實現int類型的自增。那麼就非常簡單了,自己建一個collection,然後這個collection中只有一個int的欄位,每次插入資料時來這個collection取ID就行了,然後再調用一下$inc方法,那麼就實現了自動自增的方案。

代碼展示

Python實現起來還是非常簡單的Python和Django非常契合。代碼如下:

 

def bugPlus(self):  """  bugID自增  :return:True  """  db = self.__chooseCollection(config.COLLECTION['bugID'])  db.update_one({"bugID": self.getBugID()}, {"$inc": {"bugID": 1}})  return True

 每次插入成功後,調用這個方法就可以實現ID的自增。

def getBugID(self):  """  擷取當前bug的最新編號  :return:None  """  db = self.__chooseCollection(config.COLLECTION['bugID'])  rst = db.find_one()  return rst['bugID']

在插入之前,調用這個方法,這樣每次插入資料時插入的ID就是實現自增的ID。

缺點

當然,這種方式還是有缺點的,調用的時候多使用了方法,因此需要確認方法是否執行成功,否則會導致下次插入的ID不是自增後的資料。每次多調了一次方法,會導致效能下降。

其他

如果有更好的實現方式,請告訴我!

以上這篇Python+MongoDB自增索引值的簡單實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援雲棲社區。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.