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

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

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

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

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Python 3.x

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

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

3144閲覧

django/postgresqlのエラーによりrunserverが立ち上がらない

seyu0930

総合スコア20

Django

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

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Python 3.x

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

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/05/05 01:31

前提・実現したいこと

動かして学ぶ!pythonDjango開発入門という本で学習中です。
Djangoを使いwebアプリケーションを作ろうとしているのですがrunserverでエラーが出たの解決策を教えて頂きたいです。

右も左もわからず回答していただくには質問内容が乏しいかと思いますがよろしくお願いします、、、

環境
Mac M1 version 11.3
python 3.9.2
Django 3.2

上記の本ではvenvを使っていましたが、condaを使っています。

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

/usr/local/Caskroom/miniforge/base/envs/webapp_env/bin/python /Users/haru/private_diary/manage.py runserver 2021-05-05 09:16:51,562 [INFO] /usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/utils/autoreload.py(Line:636) Watching for file changes with StatReloader Performing system checks... System check identified no issues (0 silenced). Exception in thread django-main-thread: Traceback (most recent call last): File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/backends/base/base.py", line 219, in ensure_connection self.connect() File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/utils/asyncio.py", line 26, in inner return func(*args, **kwargs) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/backends/base/base.py", line 200, in connect self.connection = self.get_new_connection(conn_params) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/utils/asyncio.py", line 26, in inner return func(*args, **kwargs) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/backends/postgresql/base.py", line 187, in get_new_connection connection = Database.connect(**conn_params) File "/Users/haru/.local/lib/python3.9/site-packages/psycopg2/__init__.py", line 127, in connect conn = _connect(dsn, connection_factory=connection_factory, **kwasync) psycopg2.OperationalError: FATAL: database "private_diary" does not exist The above exception was the direct cause of the following exception: Traceback (most recent call last): File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/threading.py", line 954, in _bootstrap_inner self.run() File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/threading.py", line 892, in run self._target(*self._args, **self._kwargs) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/utils/autoreload.py", line 64, in wrapper fn(*args, **kwargs) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/core/management/commands/runserver.py", line 121, in inner_run self.check_migrations() File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/core/management/base.py", line 486, in check_migrations executor = MigrationExecutor(connections[DEFAULT_DB_ALIAS]) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/migrations/executor.py", line 18, in __init__ self.loader = MigrationLoader(self.connection) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/migrations/loader.py", line 53, in __init__ self.build_graph() File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/migrations/loader.py", line 220, in build_graph self.applied_migrations = recorder.applied_migrations() File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/migrations/recorder.py", line 77, in applied_migrations if self.has_table(): File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/migrations/recorder.py", line 55, in has_table with self.connection.cursor() as cursor: File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/utils/asyncio.py", line 26, in inner return func(*args, **kwargs) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/backends/base/base.py", line 259, in cursor return self._cursor() File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/backends/base/base.py", line 235, in _cursor self.ensure_connection() File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/utils/asyncio.py", line 26, in inner return func(*args, **kwargs) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/backends/base/base.py", line 219, in ensure_connection self.connect() File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/utils.py", line 90, in __exit__ raise dj_exc_value.with_traceback(traceback) from exc_value File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/backends/base/base.py", line 219, in ensure_connection self.connect() File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/utils/asyncio.py", line 26, in inner return func(*args, **kwargs) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/backends/base/base.py", line 200, in connect self.connection = self.get_new_connection(conn_params) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/utils/asyncio.py", line 26, in inner return func(*args, **kwargs) File "/usr/local/Caskroom/miniforge/base/envs/webapp_env/lib/python3.9/site-packages/django/db/backends/postgresql/base.py", line 187, in get_new_connection connection = Database.connect(**conn_params) File "/Users/haru/.local/lib/python3.9/site-packages/psycopg2/__init__.py", line 127, in connect conn = _connect(dsn, connection_factory=connection_factory, **kwasync) django.db.utils.OperationalError: FATAL: database "private_diary" does not exist

試したこと

python

1django.db.utils.OperationalError: FATAL: database "private_diary" does not exist

ここからprivate_diaryというデータベースを作れていないのか思いターミナルに「psql -l]と打ちこむとprivate_diaryは作れていました。
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
----------------+-------+----------+---------+-------+-------------------
postgres | haru | UTF8 | C | C |
privatet_diary | haru | UTF8 | C | C |

以下略

python

1DATABASES = { 2 'default': { 3 'ENGINE': 'django.db.backends.postgresql_psycopg2', 4 'NAME': "private_diary", 5 "USER": os.environ.get("DB_USER"), 6 "PASSWORD": os.environ.get("DB_PASSWORD"), 7 "HOST": '', 8 "PORT": '',

settinngs.pyの方は本の通りに記述しています。

他にも諸々試しましたが一日かけても解決せず、、回答していただく上で不明な点あれば補足しますのでよろしくお願いします。

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

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

おはようございます。

問題提起に関して読ませていただきました。

djangoを使ったことないので、動くかどうかわからないですが、
'HOST': 'localhost',

に変更したらどのようになりますでしょうか?databaseと接続がうまくいっていないように感じられます。

<参考記事>
PostgreSQL 初心者向け 導入備忘録

投稿2021/05/05 02:03

編集2021/05/05 02:05
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

seyu0930

2021/05/05 04:10

回答ありがとうございます。試してみましたが同じエラーが出てしまいました。 まさしくdatabaseとの接続がうまくいってないのが原因だと思います。
seyu0930

2021/05/05 04:47

原因はわからないのですがcreatedbで新しいdatabaseを作ってそちらと接続するといけました! 自分なりに考えたのですが、private_diaryディレクトリとprivate_diaryという名前のdatabaseで名前が重複していました。database名とディレクトリ名の重複、何か今回のエラーに関係しているのでしょうか。
seyu0930

2021/05/05 05:09

お恥ずかしながらdatabaseのprivate_diaryがprivatet_diaryと打ち間違えていました、、
退会済みユーザー

退会済みユーザー

2021/05/05 10:32

あら、table名の違いだったんですね! 今後の対策として、databaseのtable確認の方法はわかってると思いますので、table確認からtable名をコピーして、ファイル内検索して単語がひっかるかどうかの確認を行うようにするとミスが減っていいですね。 おすすめのエディタはVsCodeです。 ・VsCode(https://azure.microsoft.com/ja-jp/products/visual-studio-code/) Enjoy!!!
退会済みユーザー

退会済みユーザー

2021/05/05 10:32

またわからないことがありましたら、気軽にご連絡ください。????‍♂️
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問