有没有办法相对于前一个字段自动增加一个字段...例如,如果前一个记录的值为09-0001,那么下一个记录应该分配给09-0002,那么一个......想法?我正在考虑覆盖保存方法,但我怎么不确定
答案 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)
:
+-------+------------------+------+-----+---------+----------------+
| 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
会自动增加。