亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

Python+MongoDB自增鍵值的簡單實現(xiàn)

Original 2017-01-12 15:05:12 408
abstract:背景最近在寫一個測試工具箱,里面有一個bug記錄系統(tǒng),因為后臺我是用Django和MongoDB來實現(xiàn)的,就遇到了一個問題,要如何實現(xiàn)一個自增的字段。傳統(tǒng)的關(guān)系型數(shù)據(jù)庫要實現(xiàn)起來是非常容易,只要直接設(shè)置一個自增字段就行了,插入數(shù)據(jù)時不用管這個鍵值,只管自己處理的數(shù)據(jù)就行了,會自動實現(xiàn)自增的功能,但是非關(guān)系型數(shù)據(jù)庫好像沒有這個功能(或者我不知道)。百度之后發(fā)現(xiàn)都是MongoDB的設(shè)置方法,并不是我想

背景

最近在寫一個測試工具箱,里面有一個bug記錄系統(tǒng),因為后臺我是用Django和MongoDB來實現(xiàn)的,就遇到了一個問題,要如何實現(xiàn)一個自增的字段。

傳統(tǒng)的關(guān)系型數(shù)據(jù)庫要實現(xiàn)起來是非常容易,只要直接設(shè)置一個自增字段就行了,插入數(shù)據(jù)時不用管這個鍵值,只管自己處理的數(shù)據(jù)就行了,會自動實現(xiàn)自增的功能,但是非關(guān)系型數(shù)據(jù)庫好像沒有這個功能(或者我不知道)。百度之后發(fā)現(xiàn)都是MongoDB的設(shè)置方法,并不是我想要的。

解決思路

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

我發(fā)現(xiàn)在MongoDB修改的方法有一個$inc的方法.可以實現(xiàn)int類型的自增。那么就非常簡單了,自己建一個collection,然后這個collection中只有一個int的字段,每次插入數(shù)據(jù)時來這個collection取ID就行了,然后再調(diào)用一下$inc方法,那么就實現(xiàn)了自動自增的方案。

代碼展示

Python實現(xiàn)起來還是非常簡單的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

 每次插入成功后,調(diào)用這個方法就可以實現(xiàn)ID的自增。

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

在插入之前,調(diào)用這個方法,這樣每次插入數(shù)據(jù)時插入的ID就是實現(xiàn)自增的ID。

缺點

當(dāng)然,這種方式還是有缺點的,調(diào)用的時候多使用了方法,因此需要確認方法是否執(zhí)行成功,否則會導(dǎo)致下次插入的ID不是自增后的數(shù)據(jù)。每次多調(diào)了一次方法,會導(dǎo)致性能下降。

更多關(guān)于Python+MongoDB自增鍵值的簡單實現(xiàn)請關(guān)注PHP中文網(wǎng)(ipnx.cn)其他文章!

Release Notes

Popular Entries