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

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

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

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

Ruby on Rails

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

解決済

ActiveRecord::NotNullViolation in ShopsController#create を解決したい

Guttie
Guttie

総合スコア3

Ruby on Rails 5

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

Ruby on Rails

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

1回答

0リアクション

0クリップ

487閲覧

投稿2021/12/13 12:52

#前提・実現したいこと
現在Rails でアプリを作成しています。
新しくお店を投稿しようとしたところ、以下のエラーメッセージが発生しました。
入力フォームを作成し、画像、店舗名、感想を入力してsubmitしたら,indexページへ飛ぶように設定したいです。
モデルはUser,Shopの2つです。

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

rails

ActiveRecord::NotNullViolation in ShopsController#create SQLite3::ConstraintException: shops.image_id may not be NULL: INSERT INTO "shops" ("name", "review", "user_id", "created_at", "updated_at") VALUES (?, ?, ?, ?, ?) Parameters: {"utf8"=>"✓", "authenticity_token"=>"ZD+XgDGb6ZkV0xPq2SR+d4ukFgzD11dxsHnnYY/mDFIHDX3fhUQXJfQtMDOZ20imxRcSOHMkl5NW56NtGgJ8Pw==", "shop"=> {"image"=> ["{}", #<ActionDispatch::Http::UploadedFile:0x00007fed84855d08 @content_type="image/jpeg", @headers="Content-Disposition: form-data; name=\"shop[image][]\"; filename=\"shokupan1.jpg\"\r\n" + "Content-Type: image/jpeg\r\n", @original_filename="shokupan1.jpg", @tempfile=#<File:/tmp/RackMultipart20211213-31017-3j4231.jpg>>, #<ActionDispatch::Http::UploadedFile:0x00007fed84855ba0 @content_type="image/jpeg", @headers="Content-Disposition: form-data; name=\"shop[image][]\"; filename=\"shokupan2.jpg\"\r\n" + "Content-Type: image/jpeg\r\n", @original_filename="shokupan2.jpg", @tempfile=#<File:/tmp/RackMultipart20211213-31017-15zxr7q.jpg>>], "name"=>"食パン屋さん", "review"=>"test"}, "commit"=>"投稿"}

rails

Started POST "/shops" for 180.147.217.168 at 2021-12-13 12:35:00 +0000 Cannot render console from 180.147.217.168! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255 Processing by ShopsController#create as HTML Parameters: {"utf8"=>"✓", "authenticity_token"=>"ZD+XgDGb6ZkV0xPq2SR+d4ukFgzD11dxsHnnYY/mDFIHDX3fhUQXJfQtMDOZ20imxRcSOHMkl5NW56NtGgJ8Pw==", "shop"=>{"image"=>["{}", #<ActionDispatch::Http::UploadedFile:0x00007fed84855d08 @tempfile=#<Tempfile:/tmp/RackMultipart20211213-31017-3j4231.jpg>, @original_filename="shokupan1.jpg", @content_type="image/jpeg", @headers="Content-Disposition: form-data; name=\"shop[image][]\"; filename=\"shokupan1.jpg\"\r\nContent-Type: image/jpeg\r\n">, #<ActionDispatch::Http::UploadedFile:0x00007fed84855ba0 @tempfile=#<Tempfile:/tmp/RackMultipart20211213-31017-15zxr7q.jpg>, @original_filename="shokupan2.jpg", @content_type="image/jpeg", @headers="Content-Disposition: form-data; name=\"shop[image][]\"; filename=\"shokupan2.jpg\"\r\nContent-Type: image/jpeg\r\n">], "name"=>"食パン屋さん", "review"=>"test"}, "commit"=>"投稿"}" User Load (0.1ms) SELECT "users".* FROM "users" WHERE "users"."id" = ? ORDER BY "users"."id" ASC LIMIT ? [["id", 1], ["LIMIT", 1]] ↳ /home/ec2-user/.rvm/gems/ruby-2.6.3/gems/activerecord-5.2.6/lib/active_record/log_subscriber.rb:98 Unpermitted parameter: :image (0.1ms) begin transaction ↳ app/controllers/shops_controller.rb:18 User Load (0.1ms) SELECT "users".* FROM "users" WHERE "users"."id" = ? LIMIT ? [["id", 1], ["LIMIT", 1]] ↳ app/controllers/shops_controller.rb:18 Shop Create (0.6ms) INSERT INTO "shops" ("name", "review", "user_id", "created_at", "updated_at") VALUES (?, ?, ?, ?, ?) [["name", "食パン屋さん"], ["review", "test"], ["user_id", 1], ["created_at", "2021-12-13 12:35:00.533237"], ["updated_at", "2021-12-13 12:35:00.533237"]] ↳ app/controllers/shops_controller.rb:18 (0.1ms) rollback transaction ↳ app/controllers/shops_controller.rb:18 Completed 500 Internal Server Error in 15ms (ActiveRecord: 1.0ms) ActiveRecord::NotNullViolation (SQLite3::ConstraintException: shops.image_id may not be NULL: INSERT INTO "shops" ("name", "review", "user_id", "created_at", "updated_at") VALUES (?, ?, ?, ?, ?)): app/controllers/shops_controller.rb:18:in `create'

#該当のソースコード
/app/controllers/shops_controller.rb

Ruby

class ShopsController < ApplicationController before_action :authenticate_user! def index @shops = Shop.all end def new @shop = Shop.new end def create @shop = Shop.new(shop_params) @shop.user_id = current_user.id @shop.save redirect_to shops_path end def show @shop = Shop.find(params[:id]) end def destroy end private def shop_params params.require(:shop).permit(:image, :name, :review) end end

/app/views/shops/new.html.erb

HTML

<main> <h2 class="title">NEW SHOP</h2> <div class="container"> <div class="row"> <div class="col-lg-6 mx-auto"> <h3>食パン 新規投稿フォーム</h3> <p class="text-danger mb-5">※印は必須項目です。</p> <%= form_with model: @shop, local:true do |f| %> <div class="form-group"> <%= f.label :image, "画像" %><span class="text-danger">※</span> <%= f.attachment_field :image, multiple: true %> </div> <div class="form-group"> <%= f.label :name, "店舗名" %><span class="text-danger">※</span> <%= f.text_field :name, class: "form-control" %> </div> <div class="form-group"> <%= f.label :review, "レビュー" %><span class="text-danger">※</span> <%= f.text_area :review, rows: "5", class: "form-control" %> </div> <div class="my-5"> <%= f.submit "投稿", class: "btn btn-outline-success mx-auto d-block" %> </div> <% end %> </div> </div> </div> </main>

どうかご助力願います。

以下のような質問にはリアクションをつけましょう

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

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

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

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

適切な質問に修正を依頼しましょう。

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
86.12%

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

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

質問する

関連した質問

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

Ruby on Rails 5

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

Ruby on Rails

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