我的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'
你可以改变类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,
# ...
自Django 2.x起,on_delete
是必需的。
从版本1.9开始不推荐使用:on_delete将成为Django 2.0中的必需参数。在旧版本中,它默认为CASCADE。
直到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
从Django 2.0 on_delete
是必需的:
user = models.OneToOneField(User,on_delete = models.CASCADE)
如果删除用户,它将删除子表数据。有关更多详细信息,请查看Django文档。
如果您使用foreignkey,则必须使用“on_delete = models.CASCADE”,因为它将消除从父表中删除原始元素后开发的复杂性。就如此容易。
categorie = models.ForeignKey('Categorie', on_delete=models.CASCADE)
以下是可用的选项,如果它可以帮助任何人on_delete
CASCADE,DO_NOTHING,PROTECT,SET,SET_DEFAULT,SET_NULL
从Django 2.0开始,ForeignKey字段需要两个位置参数:
categorie = models.ForeignKey('Categorie', on_delete=models.PROTECT)
以下是on_delete中可以使用的一些方法
级联删除。 Django模拟SQL约束ON DELETE CASCADE的行为,并删除包含ForeignKey的对象
通过引发ProtectedError(django.db.IntegrityError的子类)来防止删除引用的对象。
不采取行动。如果数据库后端强制实施参照完整性,则除非您手动将SQL ON DELETE约束添加到数据库字段,否则将导致IntegrityError。
你可以通过阅读documentation找到更多关于on_delete的信息。
这对我有用pip install django-csvimport --upgrade