'authorid' - это внешний ключ для модели пользователя Django. После запуска «makemigrations» и «migrate» я не вижу это поле в оболочке sqlite. Вот мои модели,Невозможно создать поле внешнего ключа в Django
class TopicModel(models.Model):
topic = models.CharField(max_length = 100)
topicAuthor = models.CharField(max_length = 100)
authorid = models.ForeignKey(User, related_name = 'id_of_author')
views = models.PositiveIntegerField(default = 0)
def __str__(self):
return self.topic
class PostModel(models.Model):
post = HTMLField(blank = True, max_length = 1000)
pub_date = models.DateTimeField('date published')
author = models.CharField(max_length = 30)
topicid = models.ForeignKey(TopicModel, related_name = 'posts')
def __str__(self):
return self.post
Как вы можете видеть postmodel также имеет внешний ключ к тематическому моделированию и нет никаких проблем с этим внешним ключом. После миграции мигрирует файл 0001_initial.py выглядит так,
from __future__ import unicode_literals
from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion
import tinymce.models
class Migration(migrations.Migration):
initial = True
dependencies = [
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
]
operations = [
migrations.CreateModel(
name='PostModel',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('post', tinymce.models.HTMLField(blank=True, max_length=1000)),
('pub_date', models.DateTimeField(verbose_name='date published')),
('author', models.CharField(max_length=30)),
],
),
migrations.CreateModel(
name='TopicModel',
fields=[
('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('topic', models.CharField(max_length=100)),
('topicAuthor', models.CharField(max_length=100)),
('views', models.PositiveIntegerField(default=0)),
('authorid', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='id_of_author', to=settings.AUTH_USER_MODEL)),
],
),
migrations.AddField(
model_name='postmodel',
name='topicid',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='posts', to='crudapp.TopicModel'),
),
]
В SQLite раскошеливаться на postmodel показывает поле с внешним ключом, который topicid_id
sqlite> PRAGMA table_info(crudapp_postmodel);
0|id|integer|1||1
1|pub_date|datetime|1||0
2|author|varchar(30)|1||0
3|topicid_id|integer|1||0
4|post|text|1||0
Но когда я делаю то же самое с topicmodel, поле с внешним ключом не существует, поэтому нет поля authorid.
sqlite> PRAGMA table_info(crudapp_topicmodel);
0|id|integer|1||1
1|topic|varchar(100)|1||0
2|topicAuthor|varchar(100)|1||0
3|views|integer unsigned|1||0
Решения: Как было предложено Аласдера я удалил файл sqlitedb и изменил поле от от TopicID и AuthorID к теме и автору.
Я предполагаю, что вы обновили файл миграции после того, как вы уже создали 'crudapp_topicmodel' в базе данных. Если у вас еще нет важных данных, самым простым решением является удаление вашего файла sqlite и повторное выполнение ./manage.py migrate'. – Alasdair
Обратите внимание, что в Django вы обычно называете ваши внешние ключи 'author' и' topic', тогда Django будет создавать столбцы 'author_id' и' topic_id'. В настоящее время у вас есть 'authorid' и' topicid', что приводит к столбцам 'authorid_id' и' topicid_id'. – Alasdair
Блестяще благодарю вас за эти предложения. –