背景
最近在寫一個測試工具箱,里面有一個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自增鍵值的簡單實現就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
