🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby

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

Ruby on Rails 6

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

Ruby on Rails

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

Q&A

解決済

1回答

1122閲覧

中間テーブルに保存ができない

fastman

総合スコア3

Ruby

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

Ruby on Rails 6

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

Ruby on Rails

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

0グッド

0クリップ

投稿2021/03/02 08:05

編集2021/03/03 04:08

前提・実現したいこと

某メッセージアプリのようにroomにはuserが1人以上いて、userはroomに属す多対多の関係の中で中間テーブルにroom_iduser_idを保存させたい

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

受け取ったパラメータが中間テーブルに保存されない

rails

1Parameters: {"authenticity_token"=>"○○", "room"=>{"thread_name"=>"サンプル", "user_ids"=>["1", "2"]}, "commit"=>"作成する"} 2 User Load (0.3ms) SELECT `users`.* FROM `users` WHERE `users`.`id` IN (1, 2) 3 ↳ app/controllers/rooms_controller.rb:21:in `create' 4 Rendering rooms/new.html.erb within layouts/application 5 User Load (0.3ms) SELECT `users`.* FROM `users` WHERE `users`.`id` = 2 ORDER BY `users`.`id` ASC LIMIT 1 6 ↳ app/views/shared/_second_header.html.erb:4 7 Rendered shared/_second_header.html.erb (Duration: 6.0ms | Allocations: 1774) 8 User Load (0.2ms) SELECT `users`.* FROM `users` 9 ↳ app/views/rooms/new.html.erb:12 10 Rendered shared/_footer.html.erb (Duration: 0.0ms | Allocations: 5) 11 Rendered rooms/new.html.erb within layouts/application (Duration: 8.0ms | Allocations: 3297) 12[Webpacker] Everything's up-to-date. Nothing to do 13Completed 200 OK in 78ms (Views: 45.2ms | ActiveRecord: 0.7ms | Allocations: 45059)

該当のソースコード

#####モデル

user

1class User < ApplicationRecord 2 has_many :room_users, dependent: :destroy 3 has_many :rooms, through: :room_users 4end

room

1class Room < ApplicationRecord 2 has_many :room_users, dependent: :destroy 3 has_many :users, through: :room_users 4end

room_user

1class RoomUser < ApplicationRecord 2 belongs_to :room 3 belongs_to :user 4end 5

#####マイグレーションファイル

roomUser

1class CreateRoomUsers < ActiveRecord::Migration[6.0] 2 def change 3 create_table :room_users do |t| 4 t.references :user, foreign_key: true 5 t.references :room, foreign_key: true 6 t.timestamps 7 end 8 end 9end 10

#####コントローラー

controller

1class RoomsController < ApplicationController 2 def new 3 @room = Room.new 4 @users = User.all 5 end 6 7 def create 8 @room = Room.create(room_params) 9 if @room.save 10 redirect_to room_messages_path(@room.id) 11 else 12 render :new 13 end 14 end 15 16 private 17 18 def room_params 19 params.require(:room).permit(:thread_name, user_ids: []) 20 end 21end

#####ビュー

new

1<%= render "shared/second_header.html.erb" %> 2 3<div class="create-form"> 4 <h1 class='create-title'>スレッドを作成する</h1> 5 <%= form_with model: @room, class: "thread-form", local: true do |f| %> 6 <div class="field"> 7 <%= f.label :thread_name, "スレッド名", class: "label-name" %> 8 <%= f.text_field :thread_name, class: "field-box" %> 9 </div> 10 <div class="field"> 11 <%= f.label :user_ids, "招待する", class: "label-name" %> 12 <%= f.collection_check_boxes :user_ids, User.all, :id, :username, include_hidden: false do |user| %> 13 <div> 14 <%= user.label { user.check_box + user.text } %> 15 </div> 16 <% end %> 17 </div> 18 <div class="creation"> 19 <%= f.submit "作成する", class: "create-btn" %> 20 </div> 21 <% end %> 22</div> 23 24<%= render "shared/footer.html.erb" %>

試したこと

コンソール側から保存できるかどうか試したが保存できなかった

console

1[1] pry(main)> Room.create(thread_name: "ルーム1", user_ids: [1, 2]) 2 (0.7ms) SET NAMES utf8, @@SESSION.sql_mode = CONCAT(CONCAT(@@sql_mode, ',STRICT_ALL_TABLES'), ',NO_AUTO_VALUE_ON_ZERO'), @@SESSION.sql_auto_is_null = 0, @@SESSION.wait_timeout = 2147483 3 User Load (0.3ms) SELECT `users`.* FROM `users` WHERE `users`.`id` IN (1, 2) 4=> #<Room:0x00007f85f8075d20 id: nil, thread_name: "ルーム1", created_at: nil, updated_at: nil>

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

devise(4.7.3)
Ruby2.6.6
Rails6.0.0

お手数ですがご教授願えると幸いです

追記

console

1[1] pry(main)> Room.create! 2ActiveRecord::RecordInvalid: translation missing: ja.activerecord.errors.messages.record_invalid 3from /Users/ユーザ名/.rbenv/versions/2.6.6/lib/ruby/gems/2.6.0/gems/activerecord-6.0.3.5/lib/active_record/validations.rb:80:in `raise_validation_error'

本記事を参考にしたところ、以下のようなエラー文が返ってきました

console

1[1] pry(main)> Room.create!(thread_name: "ルーム1", user_ids: [1, 2]) 2ActiveRecord::RecordInvalid: バリデーションに失敗しました: Usersは不正な値です 3from /Users/ ユーザ名/.rbenv/versions/2.6.6/lib/ruby/gems/2.6.0/gems/activerecord-6.0.3.5/lib/active_record/validations.rb:80:in `raise_validation_error'

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

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

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

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

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

maisumakun

2021/03/02 08:21 編集

> コンソール側から保存できるかどうか試したが保存できなかった そこで、Room.createではなくRoom.create!とすれば、例外で何が問題になっているかの詳細が出るかと思います。実行してみましたか?
fastman

2021/03/02 08:31

そのようなコマンドがあることを知りませんでした。ありがとうございます。 どうやら多言語対応していない?というもののようです。自分なりに調べてからもう一度返信させていただきますのでその際に答えていただけると幸いです。
maisumakun

2021/03/02 08:37

Room.create!(thread_name: "ルーム1", user_ids: [1, 2])としてみたらどうなりますか?
fastman

2021/03/02 15:57

全く同じエラー文が返ってきました。
neko_daisuki

2021/03/02 22:35

ID が 1 と 2 のユーザーは存在しますか?
fastman

2021/03/03 01:43

存在します。おそらくRoom.create!で返ってきたエラー文を読み解いていかないと無理そうです(・・;)
guest

回答1

0

自己解決

ユーザーモデルに書いていたパスワードにかけていたバリデーションが原因でした。上に記述していない部分でしたので修正依頼をしてくださった皆様申し訳ございません。
deviseにデフォルトでかかっているバリデーションとの兼ね合いの問題かと思います。

user

1PASSWORD_REGEX = /\A(?=.*?[a-z])(?=.*?\d)[a-z\d]+\z/i.freeze 2validates_format_of :password, with: PASSWORD_REGEX

投稿2021/03/03 05:38

fastman

総合スコア3

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問