質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

Q&A

解決済

1回答

6561閲覧

Django no such table: テーブル名 の解消法

doodai

総合スコア21

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

0グッド

0クリップ

投稿2020/05/24 08:47

編集2020/05/24 09:37

背景

DBの中の空データが悪さをしていそうだったのでこのサイトを参考にDBを消去して再マイグレーションを行いました。
その後、自分のサイトのDBに関連するページにアクセスしたところ以下のようなエラーメッセージが出ました。
このサイトに書いてあることを試してみたのですが、同じエラーメッセージが出てしまっています。
何か対処法はありますでしょうか?

ちなみにDBを消去する前まではページにアクセスすることはできていました。

どのファイルを載せるべきか分からないので、必要なものがあればおっしゃっていただけるとありがたいです。

発生している問題・エラーメッセージ

簡単な掲示板アプリを作成しており、http://0.0.0.0:8000/に投稿一覧が表示されるようにしているのですが、このページにアクセスしようとすると下記のエラーメッセージが出ます。
また、投稿作成フォームであるhttp://0.0.0.0:8000/write/は正常に表示されますが、これをhttp://0.0.0.0:8000/に送信しようとすると同様のエラーが出ます。

イメージ説明

コード

models.py(一部抜粋) ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー class Posts(models.Model): class Meta(object): db_table = 'posts' text = models.CharField(verbose_name='本文', max_length=255) created_at = models.DateField(verbose_name='作成日', default=timezone.now) def __str__(self): return self.text, self.created_at def get_absolute_url(self): return reverse('index')
urls.py ------------------------------------------------------------------ from django.urls import path from . import views urlpatterns = [ path('', views.index, name='index'), path('write/', views.write, name='write'), path('<int:pk>/comment/', views.comment, name='comment'), ]

補足情報(FW/ツールのバージョンなど)

python 3.6
django 2.2
docker 2.2
を使っています。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Yasumichi

2020/05/24 09:01 編集

どのタイミングでエラーが出るか、説明できますか。 あと、「no such table: データベース名」となっていますが、通常、テーブル名が出ると思います。それが、データベース名になっているという理解で良いでしょうか? あと、関連しそうな models.py と実際に表示されるエラーを提示できますでしょうか?
doodai

2020/05/24 09:22 編集

お早い回答ありがとうございます。 そういうことではなく、「no such table: データベース名」は「no such table: テーブル名」の間違いです。申し訳ありません。 ただいま修正いたしました。 簡単な掲示板アプリを作成しており、http://0.0.0.0:8000/に投稿一覧が表示されるようにしているのですが、このページにアクセスしようとすると上記のエラーメッセージが出ます。 また、投稿作成フォームであるhttp://0.0.0.0:8000/write/は正常に表示されますが、これをhttp://0.0.0.0:8000/に送信しようとすると同様にエラーが出ます。 このような説明で大丈夫でしょうか?
Yasumichi

2020/05/24 09:27

urls.py はどうなっていますか?
doodai

2020/05/24 09:30

追加いたしました。
Yasumichi

2020/05/24 09:37

メインで作業されている環境が分かりませんが、 アプリケーション\migrations\ にある python ファイルには、Posts に関するものが含まれていますか? あと、sqlite3 などのコマンドは使える環境でしょうか?
doodai

2020/05/24 09:45

sqlite3のコマンドは使えます。 今確認したところmigrationsファイルが消えてしまっているようです。 これが原因でしょうか?
Yasumichi

2020/05/24 09:54

それが原因だと思います。 python manage.py makemigrations app の手順が抜けたりしていませんか?
doodai

2020/05/24 10:00

長々とお付き合いいただきありがとうございました。 解決いたしました。
doodai

2020/05/24 10:01

ベストアンサーがつけられないようで非常に申し訳ないです...
Yasumichi

2020/05/24 10:03

そこは気にしないでください。
doodai

2020/05/24 10:08

ありがとうございます。
guest

回答1

0

自己解決

Yasumichiさまとの会話の通り、migrationsファイルが消去されていたことが原因でした。

python manage.py makemigrations app python manage.py migrate

をすることにより解決いたしました。

既にmigrationsファイルがある場合にマイグレーションをしたい場合には

python manage.py makemigrations python manage.py migrate

でいいようですね。

投稿2020/05/24 10:06

doodai

総合スコア21

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問