python+mongodb自增键值的简单实现

背景

最近在写一个测试工具箱,里面有一个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自增键值的简单实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持php中文网。

更多python+mongodb自增键值的简单实现相关文章请关注php中文网!

Posted in 未分类

发表评论