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

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

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

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

Model

MVCモデルの一部であるModelはアプリケーションで扱うデータとその動作を管理するために扱います。

アップロード

アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Python

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

Q&A

解決済

1回答

1267閲覧

foreign keyのあるmodelに写真が保存できるようにしたい

testma

総合スコア1

Django

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

Model

MVCモデルの一部であるModelはアプリケーションで扱うデータとその動作を管理するために扱います。

アップロード

アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Python

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

0グッド

0クリップ

投稿2022/01/05 01:55

編集2022/01/05 03:30

前提・実現したいこと

Djagoでforeign keyの理解を深めたいと思い実装していました。
以下のようにclass Images(models.Model):のpostにForeignKeyを設定し、自分でアップロードした画像をclass Images(models.Model):のimagesに保存しようとしましたが保存できませんでした。

実現したいことは主テーブルにつながるハイパーリンクをクリックすると主テーブルにリンクした従テーブルに保存された写真が表示されるという機能を目指しています。

(写真の保存機能については、class Post(models.Model):とclass tes(models.Model):では保存できたのですが、foreign keyのあるclass Images(models.Model):では保存できない、なぜかはわかりません)

Django

1from django.db import models 2from django.conf import settings 3from django.utils import timezone 4 5class Post(models.Model): 6 image = models.ImageField(upload_to='images', verbose_name='イメージ画像', null=True, blank=True) 7 text = models.TextField('テキスト', null=True, blank=True) 8 upload = models.FileField(upload_to='file/%Y/%m/%d', null=True, blank=True) 9 10class Images(models.Model): 11 images = models.ImageField(upload_to='images', verbose_name='イメージ画像', null=True, blank=True) 12 post = models.ForeignKey(Post, on_delete=models.CASCADE) 13 14class tes(models.Model): 15 images = models.ImageField(upload_to='images', verbose_name='イメージ画像', null=True, blank=True) 16

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

発生しているエラーは以下に記します。

IntegrityError at /app/main NOT NULL constraint failed: app_images.post_id Request Method: POST Request URL: http://localhost-yoshi-2.paiza-user-lite.cloud:8000/app/main Django Version: 3.0.2 Exception Type: IntegrityError Exception Value: NOT NULL constraint failed: app_images.post_id Exception Location: /usr/local/lib/python3.6/dist-packages/django/db/backends/sqlite3/base.py in execute, line 396 Python Executable: /usr/bin/python3 Python Version: 3.6.9 Python Path: ['/home/ubuntu/mysite', '/usr/lib/python36.zip', '/usr/lib/python3.6', '/usr/lib/python3.6/lib-dynload', '/home/ubuntu/.local/lib/python3.6/site-packages', '/usr/local/lib/python3.6/dist-packages', '/usr/lib/python3/dist-packages']

該当のソースコード

全体のソースコードを以下に記します。

model

1from django.db import models 2from django.conf import settings 3from django.utils import timezone 4 5class Post(models.Model): 6 image = models.ImageField(upload_to='images', verbose_name='イメージ画像', null=True, blank=True) 7 text = models.TextField('テキスト', null=True, blank=True) 8 upload = models.FileField(upload_to='file/%Y/%m/%d', null=True, blank=True) 9 10class Images(models.Model): 11 images = models.ImageField(upload_to='images', verbose_name='イメージ画像', null=True, blank=True) 12 post = models.ForeignKey(Post, on_delete=models.CASCADE) 13 14class tes(models.Model): 15 images = models.ImageField(upload_to='images', verbose_name='イメージ画像', null=True, blank=True) 16

views

1def main(request): 2 if request.method == 'POST': 3 form = PostForm(request.POST or None) 4 if form.is_valid(): 5 for f in request.FILES.getlist('image'): 6 7 p = Images(images=f) 8 p.save() 9 10 else: 11 form = PostForm() 12 return render(request, 'app/main.html', {'form': form,})

forms

1from django import forms 2class PostForm(forms.Form): 3 image = forms.ImageField(label='イメージ画像', required=False,widget=forms.ClearableFileInput(attrs={'multiple': True}))# 追加 4

試したこと

ここに問題に対して試したことを記載してください。

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

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

post_idがnullなのが原因ではないでしょうか?
Imageに紐付けるPostのidが必要です

投稿2022/01/05 09:20

komasan1

総合スコア257

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

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

testma

2022/01/05 12:19 編集

ご回答していただきありがとうございます。 ImageにPostのidを紐付けづける、具体的な方法とかご存じでしょうか? よろしければご教示していただきたいです。
komasan1

2022/01/05 12:41

app_imagesテーブルのpost_idがnullにならないように、postテーブルのidを指定して保存する必要があります
testma

2022/01/06 13:25

お返しが遅くなり申し訳ございません。 komasan1様の保存方法で実装できました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問