获取TypeError:__ init __()缺少1个必需的位置参数:'on_delete'尝试在带有条目的子表后添加父表

问题描述 投票:66回答:7

我的sqlite数据库中有两个类,一个名为Categorie的父表和一个名为Article的子表。我首先创建了子表类并添加了条目。所以首先我有这个:

class Article(models.Model):
    titre=models.CharField(max_length=100)
    auteur=models.CharField(max_length=42)
    contenu=models.TextField(null=True)
    date=models.DateTimeField(
        auto_now_add=True,
        auto_now=False,
        verbose_name="Date de parution"
    )

    def __str__(self):
        return self.titre

在我添加了父表之后,现在我的models.py看起来像这样:

from django.db import models

# Create your models here.
class Categorie(models.Model):
    nom = models.CharField(max_length=30)

    def __str__(self):
        return self.nom


class Article(models.Model):
    titre=models.CharField(max_length=100)
    auteur=models.CharField(max_length=42)
    contenu=models.TextField(null=True)
    date=models.DateTimeField(
        auto_now_add=True,
        auto_now=False,
        verbose_name="Date de parution"
    )
    categorie = models.ForeignKey('Categorie')

    def __str__(self):
        return self.titre

所以,当我运行python manage.py makemigrations <my_app_name>时,我收到此错误:

Traceback (most recent call last):
  File "manage.py", line 15, in <module>
    execute_from_command_line(sys.argv)
  File "C:\Users\lislis\AppData\Local\Programs\Python\Python35-32\lib\site-packages\django-2.0-py3.5.egg\django\core\management\__init__.py", line 354, in execute_from_command_line
    utility.execute()
  File "C:\Users\lislis\AppData\Local\Programs\Python\Python35-32\lib\site-packages\django-2.0-py3.5.egg\django\core\management\__init__.py", line 330, in execute
    django.setup()
  File "C:\Users\lislis\AppData\Local\Programs\Python\Python35-32\lib\site-packages\django-2.0-py3.5.egg\django\__init__.py", line 24, in setup
    apps.populate(settings.INSTALLED_APPS)
  File "C:\Users\lislis\AppData\Local\Programs\Python\Python35-32\lib\site-packages\django-2.0-py3.5.egg\django\apps\registry.py", line 112, in populate
    app_config.import_models()
  File "C:\Users\lislis\AppData\Local\Programs\Python\Python35-32\lib\site-packages\django-2.0-py3.5.egg\django\apps\config.py", line 198, in import_models
    self.models_module = import_module(models_module_name)
  File "C:\Users\lislis\AppData\Local\Programs\Python\Python35-32\lib\importlib\__init__.py", line 126, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 986, in _gcd_import
  File "<frozen importlib._bootstrap>", line 969, in _find_and_load
  File "<frozen importlib._bootstrap>", line 958, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 673, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 665, in exec_module
  File "<frozen importlib._bootstrap>", line 222, in _call_with_frames_removed
  File "C:\Users\lislis\Django\mon_site\blog\models.py", line 6, in <module>
    class Article(models.Model):
  File "C:\Users\lislis\Django\mon_site\blog\models.py", line 16, in Article
    categorie = models.ForeignKey('Categorie')
TypeError: __init__() missing 1 required positional argument: 'on_delete'

我在stackoverflow中看到了一些类似的问题,但它似乎不是同一个问题:__init__() missing 1 required positional argument: 'quantity'

python django django-models django-2.0
7个回答
108
投票

你可以改变类categorie的属性Article

categorie = models.ForeignKey(
    'Categorie',
    on_delete=models.CASCADE,
)

并且错误应该消失。

最后,您可能需要on_delete的其他选项,请查看文档以获取更多详细信息:

https://docs.djangoproject.com/en/1.11/ref/models/fields/#django.db.models.ForeignKey

编辑:

正如您在评论中所述,您对on_delete没有任何特殊要求,您可以使用DO_NOTHING选项:

# ...
on_delete=models.DO_NOTHING,
# ...

32
投票

自Django 2.x起,on_delete是必需的。

Django Documentation

从版本1.9开始不推荐使用:on_delete将成为Django 2.0中的必需参数。在旧版本中,它默认为CASCADE。


9
投票

直到Django 1.9,模型如下所示:

from django.db import models
class Article(models.Model):
    category = models.ForeignKey(Category)
    title =  models.CharField(max_length=55)
    # ...

    def __str__(self):
        return self.title

ForeignKey是用于定义多对一关系的Django字段。

直到Django 1.9,ForeignKey字段需要一个参数:要映射到的模型。

从Django 2.0开始,ForeignKey字段需要两个位置参数:

1-映射到的模型

2 - on_delete参数

要快速修复“缺少1个必需的位置参数:on_delete”更新模型:

from django.db import models
class Article(models.Model):
    category = models.ForeignKey('Category', on_delete=models.PROTECT)
    title =  models.CharField(max_length=55)
    # ...

    def __str__(self):
        return self.title

修复ForeignKey后,您将能够毫无困难地运行迁移:

python manage.py migrate

Thanks to Valentino


8
投票

从Django 2.0 on_delete是必需的:

user = models.OneToOneField(User,on_delete = models.CASCADE)

如果删除用户,它将删除子表数据。有关更多详细信息,请查看Django文档。


5
投票

如果您使用foreignkey,则必须使用“on_delete = models.CASCADE”,因为它将消除从父表中删除原始元素后开发的复杂性。就如此容易。

categorie = models.ForeignKey('Categorie', on_delete=models.CASCADE)

3
投票

以下是可用的选项,如果它可以帮助任何人on_delete

CASCADE,DO_NOTHING,PROTECT,SET,SET_DEFAULT,SET_NULL


2
投票

从Django 2.0开始,ForeignKey字段需要两个位置参数:

  1. 要映射到的模型
  2. on_delete参数
categorie = models.ForeignKey('Categorie', on_delete=models.PROTECT)

以下是on_delete中可以使用的一些方法

  1. 级联

级联删除。 Django模拟SQL约束ON DELETE CASCADE的行为,并删除包含ForeignKey的对象

  1. 保护

通过引发ProtectedError(django.db.IntegrityError的子类)来防止删除引用的对象。

  1. 没做什么

不采取行动。如果数据库后端强制实施参照完整性,则除非您手动将SQL ON DELETE约束添加到数据库字段,否则将导致IntegrityError。

你可以通过阅读documentation找到更多关于on_delete的信息。


0
投票

这对我有用pip install django-csvimport --upgrade

© www.soinside.com 2019 - 2024. All rights reserved.