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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

3222閲覧

NotNullViolation: SQLite3::ConstraintExceptionというエラーに悩まされております。

ko-u

総合スコア61

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2018/10/18 05:41

Ruby初心者です。
ググっても、中々エラー解決することが出来なかったので、こちらに投稿させて頂きます。

rails testをした際に以下のようなエラーが表示されました。

ActiveRecord::NotNullViolation: SQLite3::ConstraintException: NOT NULL constraint failed: photos.post_id: INSERT INTO "photos" ("created_at", "updated_at", "id") VALUES ('2018-10-18 05:23:29.257167', '2018-10-18 05:23:29.257167', 980190962)

Photoテーブルが空になっているのか?と思い、
コンソールを使い、Photoテーブルの中身を見たのですが

#<ActiveRecord::Relation [#<Photo id: 1, image: "icon.png", post_id: 1, created_at: "2018-10-18 05:23:14", updated_at:"2018-10-18 05:23:14">]> irb(main):004:0>

となっておりました。

どちらに原因が考えられるのでしょうか??

答えて頂けたら、大変嬉しいです。

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

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

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

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

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

kaba

2018/10/18 05:57 編集

INSERTしようとしているデータはプログラムで生成したデータで、 ActiveRecordのデータはDBから取得したデータのように見えます。 INSERTしようとしているデータはpost_idがnullなのでエラーになっているように見えます。
ko-u

2018/10/18 06:05

rails dbでデータベースを開いた直後に、INSERT INTO "photos" ("created_at", "updated_at", "id") VALUES ('2018-10-18 05:23:29.257167', '2018-10-18 05:23:29.257167', 980190962)を打ち込んだところ、何も変わりませんでした。。
guest

回答1

0

自己解決

テーブルをリセットしたら、エラーは消えました。

ありがとうございました。

投稿2018/10/19 03:18

ko-u

総合スコア61

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問