現在Djangoで入力フォームから受け取ったデータをデータベースに保存して、
それをadminサイトから参照・編集できるようにしたいと考えています。
しかし下記参考サイトの手順通りにフォームから受け取ったデータをデータベースに保存する方法を学んできましたが、
参考サイト最下部の動作確認のパターン『名前 に「テスト名」と入力した場合』が上手く動作しません。
https://eiry.bitbucket.io/tutorials/tutorial/models.html
残り二つの動作確認パターンはクリアしていて、
フォームに何か文字列を入力して送信すると以下のエラーが表示されます。
NOT NULL constraint failed: hello_hello.title
Request Method: POST
Request URL: http://127.0.0.1:8000/models/
Django Version: 1.8
Exception Type: IntegrityError
Exception Value:NOT NULL constraint failed: hello_hello.title
Exception Location: C:中略\Python36-32\lib\site-packages\django\db\backends\sqlite3\base.py in execute, line 318
Python Executable: C:中略\Python36-32\python3.exe
エラー内容を自力で調べてみましたが「NOT NULL成約」云々が問題となっていることは分かるものの、
肝心の「NOT NULL成約」とは何なのかを分かり易く説明しているサイトが見当たらず途方に暮れています。
また、上記参考サイト中央あたりの『Modelクラスをデータベースのスキーマに反映しよう』の部分では
makemigrationsを行うと二つの選択肢を選ぶ画面が表示され、たしか1番を選んだ後で再度makemigrationsとmigrateを行うと、
その後は正常に(?)migrateできるようになったみたいです。が、これが原因で上記のエラーが起こっているのかどうかもわかりません。
以上のように現在データベースに関する知識が不足していて上手く質問することもままならないため、
「NOT NULL成約」云々やdjangoとデータベースの連携に関して学べる、参考になるサイトなどお教え頂けないでしょうか?
また、一応現在の各種ファイルの記述内容で上記エラーに関わっていそうな怪しい部分を下に記しておきますので、
この部分がエラーを引き起こしているかもしれないなど、気になる部分があればご指摘をお願い致します。よろしくお願い致します。
models.py:
python
1class Hello(models.Model): 2 your_name = models.CharField(max_length=10) 3 4 def __str__(self): 5 return "<{0}>".format(self.your_name)
views.py:
python
1def hello_models(request): 2 form = forms.HelloForm(request.POST) 3 if form.is_valid(): 4 models.Hello.objects.create(**form.cleaned_data) 5 return redirect('Hello:hello_models') 6 d = { 7 'form': form, 8 'hello_qs': models.Hello.objects.all().order_by('-id') 9 } 10 return render(request, 'hello/models.html', d)
models.html:
html
1 <h1>your_nameを登録する</h1> 2 <h2>登録</h2> 3 <form method="post" action=""> 4 {{ form.errors.your_name }} 5 <label>{{ form.your_name.label }} {{ form.your_name }}</label><br> 6 <input type="submit" value="送信"> 7 {% csrf_token %} 8 </form> 9 <hr> 10 <h2>一覧</h2> 11 {% for h in hello_qs %} 12 {{ h.your_name }}<br>
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/05/30 04:44