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

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

ただいまの
回答率

90.34%

  • Python

    9211questions

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

  • Python 3.x

    7402questions

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

  • MySQL

    6176questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • Django

    1176questions

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

Djangoでフォームから受け取ったデータをデータベースに保存し、それをadminサイトから参照・編集できるようにしたい。

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 321

nayuki55

score 1

現在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:

class Hello(models.Model):
    your_name = models.CharField(max_length=10)

    def __str__(self):
        return "<{0}>".format(self.your_name)

views.py:

def hello_models(request):
    form = forms.HelloForm(request.POST)
    if form.is_valid():
        models.Hello.objects.create(**form.cleaned_data)
        return redirect('Hello:hello_models')
    d = {
        'form': form,
        'hello_qs': models.Hello.objects.all().order_by('-id')
    }
    return render(request, 'hello/models.html', d)

models.html:

  <h1>your_nameを登録する</h1>
  <h2>登録</h2>
  <form method="post" action="">
    {{ form.errors.your_name }}
    <label>{{ form.your_name.label }} {{ form.your_name }}</label><br>
    <input type="submit" value="送信">
    {% csrf_token %}
  </form>
  <hr>
  <h2>一覧</h2>
  {% for h in hello_qs %}
    {{ h.your_name }}<br>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

NOT NULL 制約は、その列に入るデータを省略できないことを意味します。たとえば、IDとNAME列をもつテーブルがあった場合でID列にのみNOT NULL制約が付与されているとします。

その場合以下のようになります。

ID列にいれるデータ NAME列にいれるデータ INSERT可能?
1 test OK
  test NG(NOT NULL制約違反)
1   OK

ご提示されているエラーをみるとhello_hello.titleでの制約違反のようですがmodels.pyHelloクラスには以前titleを定義されていませんでしたか?おそらくフォームの入力画面はyour_nameしかないものの、実際にはDB上にtitle列があることで、そに何もデータが入らないためNOT NULL制約違反になっていると思われます。

おそらくmanage.pyと同じ場所にdb.sqlite3というDBファイルができているはずですので、それを一旦別の場所においた後で

python manage.py makemigrations
python manage.py migrate

と実行すればDBファイルが再作成されて問題が解消するのではと思われます。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/05/30 13:44

    丁寧な解説ありがとうございます!ご説明頂きました手順で無事解決しました。DBファイルや各種記述の意味も分かってきてとても参考になりました。

    キャンセル

同じタグがついた質問を見る

  • Python

    9211questions

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

  • Python 3.x

    7402questions

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

  • MySQL

    6176questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • Django

    1176questions

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

  • トップ
  • Pythonに関する質問
  • Djangoでフォームから受け取ったデータをデータベースに保存し、それをadminサイトから参照・編集できるようにしたい。