123

我的 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'

4

10 回答 10

211

您可以像这样更改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,
# ...
于 2017-05-17T13:49:52.097 回答
49

由于 Django 2.x,on_delete是必需的。

Django 文档

1.9 版后已弃用:on_delete 将成为 Django 2.0 中的必需参数。在旧版本中,它默认为 CASCADE。

于 2018-02-25T18:56:44.793 回答
15

从 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. 保护

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

  1. 没做什么

不采取行动。如果您的数据库后端强制执行引用完整性,这将导致 IntegrityError,除非您手动将 SQL ON DELETE 约束添加到数据库字段。

您可以通过阅读文档找到更多关于 on_delete 的信息。

于 2019-04-19T16:51:01.833 回答
14

从 Django 2.0 开始on_delete是必需的:

用户 = models.OneToOneField(用户,on_delete=models.CASCADE)

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

于 2018-04-04T20:01:06.640 回答
4

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

categorie = models.ForeignKey('Categorie', on_delete=models.CASCADE)
于 2018-06-02T07:09:41.193 回答
3

如果它对 on_delete 的任何人有帮助,这里有可用的选项

级联、DO_NOTHING、保护、设置、SET_DEFAULT、SET_NULL

于 2018-08-02T08:34:13.303 回答
3

发布 Django 版本 1.9,on_delete成为必需的参数,即来自 Django 2.0。

在旧版本中,它默认为 CASCADE。

因此,如果您想复制您在早期版本中使用的功能。使用以下参数。

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

这将具有与早期版本相同的效果,无需明确指定。

关于与 on_delete 相关的其他参数的官方文档

于 2020-07-02T16:46:32.020 回答
1

如果您不知道输入参数的选项。只想保持on_delete=None迁移前的默认值:

on_delete=models.CASCADE

这是旧版本中的代码片段:

if on_delete is None:
    warnings.warn(
        "on_delete will be a required arg for %s in Django 2.0. Set "
        "it to models.CASCADE on models and in existing migrations "
        "if you want to maintain the current default behavior. "
        "See https://docs.djangoproject.com/en/%s/ref/models/fields/"
        "#django.db.models.ForeignKey.on_delete" % (
            self.__class__.__name__,
            get_docs_version(),
        ),
        RemovedInDjango20Warning, 2)
    on_delete = CASCADE
于 2020-02-11T07:58:31.137 回答
0

通过将这两个参数添加到 ForeignKey 解决了类似的问题:null=True, on_delete=models.SET_NULL

于 2020-04-24T17:55:02.647 回答
-4

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

于 2019-05-26T06:45:49.240 回答