2016-05-16 4 views
1

'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 к теме и автору.

+0

Я предполагаю, что вы обновили файл миграции после того, как вы уже создали 'crudapp_topicmodel' в базе данных. Если у вас еще нет важных данных, самым простым решением является удаление вашего файла sqlite и повторное выполнение ./manage.py migrate'. – Alasdair

+0

Обратите внимание, что в Django вы обычно называете ваши внешние ключи 'author' и' topic', тогда Django будет создавать столбцы 'author_id' и' topic_id'. В настоящее время у вас есть 'authorid' и' topicid', что приводит к столбцам 'authorid_id' и' topicid_id'. – Alasdair

+1

Блестяще благодарю вас за эти предложения. –

ответ

1

Ваша текущая миграция должна создавать внешние ключи. Я предполагаю, что вы обновили файл миграции после того, как вы уже создали таблицу crudapp_topicmodel в базе данных.

Если у вас еще нет важных данных, самое простое исправить - удалить ваш файл sqlite и повторно запустить ./manage.py migrate.

Смежные вопросы