Home > Backend Development > Python Tutorial > Simple implementation of Python+MongoDB auto-increment key value

Simple implementation of Python+MongoDB auto-increment key value

高洛峰
Release: 2017-02-22 11:05:43
Original
1826 people have browsed it

Background

Recently I was writing a testing toolbox, which has a bug recording system. Because I used Django and MongoDB to implement the background, I encountered a The question is, how to implement an auto-incrementing field.

It is very easy to implement a traditional relational database. You just need to directly set an auto-increment field. When inserting data, you don’t need to worry about this key value. Just worry about the data you process. The auto-increment will be automatically implemented. function, but non-relational databases don’t seem to have this function (or I don’t know). Baidu later discovered that they were all MongoDB setting methods, which were not what I wanted.

Solution ideas

Baidu has not found a good idea, so it can only solve it by itself. My idea is very simple, and the fields will not Self-increasing, then create a self-increasing plan yourself.

I found that the method modified in MongoDB has a $inc method, which can realize the auto-increment of int type. Then it's very simple. Create a collection yourself, and then there is only one int field in this collection. Every time you insert data, just come to this collection to get the ID, and then call the $inc method, then automatic increment will be realized. plan.

Code display

Python is still very simple to implement. Python and Django are very compatible. The code is as follows:

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

After each insertion is successful, calling this method can realize the automatic increment of the ID.

def getBugID(self):
  """
  获取当前bug的最新编号
  :return:None
  """
  db = self.__chooseCollection(config.COLLECTION['bugID'])
  rst = db.find_one()
  return rst['bugID']
Copy after login

Before inserting, call this method, so that the ID inserted every time data is inserted is the ID that is auto-incremented.

Disadvantages

Of course, this method still has shortcomings. More methods are used when calling, so the method needs to be confirmed. Whether the execution is successful, otherwise the ID inserted next time will not be the data after the auto-increment. Each time the method is called more than once, performance will decrease.

Others

If there is a better way to implement it, please tell me!

The above simple implementation of Python+MongoDB's self-increasing key value is all the content shared by the editor. I hope it can give you a reference, and I hope you will support the PHP Chinese website.

For more articles related to the simple implementation of Python+MongoDB’s self-increasing key value, please pay attention to the PHP Chinese website!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template