TypeError: init() missing 1 required positional argument: ‘on_delete’
问题:在django2.0中,models.py定义表数据时,使用django迁移表数据时报错
解决办法:
创建外键ForeignKey或者OneToOne时,必须要加一个参数on_delete,否则会报错
而ManyToManyField多对多中,没有该参数,不需要添加。
# 多对多 参数中不能有on_delete
class UserInfo(models.Model):
"""
用户表
"""
name = models.CharField(verbose_name='用户名', max_length=32)
password = models.CharField(verbose_name='密码', max_length=64)
email = models.CharField(verbose_name='邮箱', max_length=32)
roles = models.ManyToManyField(verbose_name='拥有的所有角色', to='Role', blank=True)
def __str__(self):
return self.name
# 添加外键 参数中必须有on_delete
class Payment(models.Model):
"""
付费记录
"""
customer = models.ForeignKey(verbose_name='关联客户', to='Customer',on_delete=models.CASCADE)
money = models.IntegerField(verbose_name='付费金额')
create_time = models.DateTimeField(verbose_name='付费时间', auto_now_add=True)
on_delete参数的意思时,删除这个字段时,外键关联的表记录也要同步删除这个字段相关的记录。