相对于前一个值,自动增加Django中的值

时间:2009-06-30 18:01:42

标签: django auto-increment

有没有办法相对于前一个字段自动增加一个字段...例如,如果前一个记录的值为09-0001,那么下一个记录应该分配给09-0002,那么一个......想法?我正在考虑覆盖保存方法,但我怎么不确定

3 个答案:

答案 0 :(得分:8)

Django不允许您在模型中拥有多个AutoField,并且您已经有一个用于主键。所以你必须覆盖保存,可能需要回顾一下表来确定要增加的内容。

这样的事情:

class Product(models.Model): 
   code = models.IntegerField()
   number = models.IntegerField()
   ...

   def get_serial_number(self): 
      "Get formatted value of serial number"
      return "%.2d-%.3d" % (self.code, self.product)

   def save(self): 
      "Get last value of Code and Number from database, and increment before save"
      top = Product.objects.order_by('-code','-number')[0]
      self.code = top.code + 1
      self.number = top.number + 1
      super(Product, self).save()

   # etc.

请注意,如果在save方法中没有某种锁定,则可能会遇到并发问题(两个线程试图在代码和数字中存储相同的值)。

答案 1 :(得分:1)

AutoField是Django用于模型基类“id”属性的字段类型,但您可以将其用于其他自动增量字段。

我认为你不能像你的例子那样进行任何格式化,但一个好的方法是创建一个自定义字段类型来覆盖save()方法以执行所需的格式化。

答案 2 :(得分:1)

SQL中的

+-------+------------------+------+-----+---------+----------------+
| Field | Type             | Null | Key | Default | Extra          |
+-------+------------------+------+-----+---------+----------------+
| code  | int(11) unsigned | NO   | PRI | NULL    | auto_increment |
+-------+------------------+------+-----+---------+----------------+

在Django中:

self.code = None
self.number = top.number + 1
self.save() # or super(Product, self).save()

保存后,code会自动增加。