2016-04-27 13 views
2

私はモデル言語を作成しました。私はmakemigrationsmigrateの部分をしました。すべてうまくいった。私はdbを設定ファイルに登録しました。私は問題を見ないDjango Admin no such table

from django.db import models 

class Oxn(models.Model): 
    objectId = models.CharField(max_length=100, unique=True) 
    name = models.CharField(max_length=100) 
    picture = models.CharField(max_length=200) 

class Language(models.Model): 
    objectId = models.CharField(max_length=100, unique=True) 
    code = models.CharField(max_length=10) 
    language = models.CharField(max_length=100) 

:私のモデルは、次のように定義されて

OperationalError at /admin/testdb/language/ 
no such table: testdb_language 
Request Method: GET 
Request URL: http://localhost:8000/admin/testdb/language/ 
Django Version: 1.9.5 
Exception Type: OperationalError 
Exception Value:  
no such table: testdb_language 
Exception Location: /Users/nep/Documents/Development/Private/testdjango/myvenv/lib/python3.5/site-packages/django/db/backends/sqlite3/base.py in execute, line 323 
Python Executable: /Users/nep/Documents/Development/Private/testdjango/myvenv/bin/python 
Python Version: 3.5.1 
Python Path:  
['/Users/nep/Documents/Development/Private/testdjango', 
'/Library/Frameworks/Python.framework/Versions/3.5/lib/python35.zip', 
'/Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5', 
'/Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/plat-darwin', 
'/Library/Frameworks/Python.framework/Versions/3.5/lib/python3.5/lib-dynload', 
'/Users/nep/Documents/Development/Private/testdjango/myvenv/lib/python3.5/site-packages'] 

:私はこれを取得、管理ページに言語テーブルをクリックし

。誰か助けてくれますか?

EDIT:移行から

0001_initial.pyコンテンツ下記た

(myvenv) ➜ gins4udjango python manage.py showmigrations  
admin 
[X] 0001_initial 
[X] 0002_logentry_remove_auto_add 
auth 
[X] 0001_initial 
[X] 0002_alter_permission_name_max_length 
[X] 0003_alter_user_email_max_length 
[X] 0004_alter_user_username_opts 
[X] 0005_alter_user_last_login_null 
[X] 0006_require_contenttypes_0002 
[X] 0007_alter_validators_add_error_messages 
contenttypes 
[X] 0001_initial 
[X] 0002_remove_content_type_name 
ginsdb 
[X] 0001_initial 
sessions 
[X] 0001_initial 

EDIT:これは移行の出力は

ある

# -*- coding: utf-8 -*- 
# Generated by Django 1.9.5 on 2016-04-29 14:51 
from __future__ import unicode_literals 

from django.db import migrations, models 
import django.db.models.deletion 


class Migration(migrations.Migration): 

    initial = True 

    dependencies = [ 
    ] 

    operations = [ 
     migrations.CreateModel(
      name='Country', 
      fields=[ 
       ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), 
       ('objectId', models.CharField(max_length=100, unique=True)), 
       ('name', models.CharField(max_length=100)), 
      ], 
     ), 
     migrations.CreateModel(
      name='Gin', 
      fields=[ 
       ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), 
       ('objectId', models.CharField(max_length=100, unique=True)), 
       ('alcohol', models.FloatField(blank=True, default=None, null=True)), 
       ('name', models.CharField(max_length=100)), 
       ('picture', models.CharField(max_length=200)), 
      ], 
     ), 
     migrations.CreateModel(
      name='GinLocal', 
      fields=[ 
       ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), 
       ('objectId', models.CharField(max_length=100, unique=True)), 
       ('origin', models.TextField()), 
       ('serve', models.TextField()), 
       ('aroma', models.TextField()), 
       ('country', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='ginsdb.Country', to_field='objectId')), 
       ('gin', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='ginsdb.Gin', to_field='objectId')), 
      ], 
     ), 
     migrations.CreateModel(
      name='Language', 
      fields=[ 
       ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), 
       ('objectId', models.CharField(max_length=100, unique=True)), 
       ('code', models.CharField(max_length=10)), 
       ('language', models.CharField(max_length=100)), 
      ], 
     ), 
     migrations.CreateModel(
      name='Type', 
      fields=[ 
       ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), 
       ('objectId', models.CharField(max_length=100, unique=True)), 
       ('typeName', models.CharField(max_length=100)), 
       ('language', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='ginsdb.Language', to_field='objectId')), 
      ], 
     ), 
     migrations.AddField(
      model_name='ginlocal', 
      name='language', 
      field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='ginsdb.Language', to_field='objectId'), 
     ), 
     migrations.AddField(
      model_name='ginlocal', 
      name='types', 
      field=models.ManyToManyField(to='ginsdb.Type'), 
     ), 
     migrations.AddField(
      model_name='country', 
      name='language', 
      field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='ginsdb.Language', to_field='objectId'), 
     ), 
    ] 
+0

'./manage.py showmigrations'と表示すると、次のコマンドを実行して、モデルを作成するために必要なSQLを表示できます: 'testdb'アプリケーションの移行内容は何ですか? – Alasdair

+0

トピックに追加しました – user1007522

+0

'Language'と' Oxn'のアプリはどちらですか?それは本当に 'testdb'と呼ばれていますか? – Alasdair

答えて

3

0001_initial移行のginsdbアプリにはが含まれていますモデルなので、移行を実行したときに作成されているはずです。

まだ開発中で重要なデータがない場合、最も簡単なのはデータベースを削除し、新しいデータベースの移行を再実行することです。単にsqliteデータベースファイルを削除し、./manage.py migrateを再度実行してください。

データベースを保持する必要がある場合は、手動でモデルを作成することもできますが、これは扱いにくいものになります。

./manage.py sqlmigrate ginsdb 0001_initial 
+0

私はまだその問題をしました。 – user1007522

+0

ありがとうございます。独自の移行を行う前に、manage.py migrate authを実行するだけでした。だから、.sqlファイルを削除して、すべてをやり直してください:-)。 – user1007522

+1

マイグレーションファイルで依存関係を 'dependencies = [(u'auth '、' __first __ ')]'に変更した場合、Djangoはそれらを正しい順序で実行しますので、手動で実行する必要はありません。最初に認証移行。 – Alasdair

関連する問題