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

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

詳細はこちら
Ruby on Rails 6

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

Q&A

解決済

1回答

827閲覧

Rails6 insert_all 使いかた

mbaby__8

総合スコア66

Ruby on Rails 6

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

0グッド

0クリップ

投稿2021/01/13 06:12

編集2021/01/13 06:29

レコードの複数登録を行いたく、試しにscaffoldで作ったサイトに、insert_allを用いて

まとめてフォーム画面から登録できるようにしたいのですが

insert_allはこの場合どこに使えば、使えるようになるのでしょうか?

Searchモデル titleカラム urlカラム

でやっています。

教えて頂けると幸いです。

controller

1class Maryu::SearchesController < Maryu::Base 2 before_action :set_search, only: [:show, :edit, :update, :destroy] 3 4 # GET /searches 5 # GET /searches.json 6 def index 7 @searches = Search.all 8 end 9 10 # GET /searches/1 11 # GET /searches/1.json 12 def show 13 end 14 15 # GET /searches/new 16 def new 17 @search = Search.new 18 end 19 20 # GET /searches/1/edit 21 def edit 22 end 23 24 # POST /searches 25 # POST /searches.json 26 def create 27 @search = Search.new(search_params) 28 29 respond_to do |format| 30 if @search.save 31 format.html { redirect_to "maryu/searches", notice: 'Search was successfully created.' } 32 format.json { render :show, status: :created, location: @search } 33 else 34 format.html { render :new } 35 format.json { render json: @search.errors, status: :unprocessable_entity } 36 end 37 end 38 end 39 40 # PATCH/PUT /searches/1 41 # PATCH/PUT /searches/1.json 42 def update 43 respond_to do |format| 44 if @search.update(search_params) 45 format.html { redirect_to @search, notice: 'Search was successfully updated.' } 46 format.json { render :show, status: :ok, location: @search } 47 else 48 format.html { render :edit } 49 format.json { render json: @search.errors, status: :unprocessable_entity } 50 end 51 end 52 end 53 54 # DELETE /searches/1 55 # DELETE /searches/1.json 56 def destroy 57 @search.destroy 58 respond_to do |format| 59 format.html { redirect_to searches_url, notice: 'Search was successfully destroyed.' } 60 format.json { head :no_content } 61 end 62 end 63 def search 64 if params[:title].present? 65 @searches = Search.where('title LIKE ?', "%#{params[:title]}%") 66 else 67 @searches = Search.none 68 end 69 end 70 private 71 # Use callbacks to share common setup or constraints between actions. 72 def set_search 73 @search = Search.find(params[:id]) 74 end 75 76 # Only allow a list of trusted parameters through. 77 def search_params 78 params.require(:search).permit(:title, :url) 79 end 80end 81

form

1<%= form_with(model: search, local: true) do |form| %> 2 <% if search.errors.any? %> 3 <div id="error_explanation"> 4 <h2><%= pluralize(search.errors.count, "error") %> prohibited this search from being saved:</h2> 5 6 <ul> 7 <% search.errors.full_messages.each do |message| %> 8 <li><%= message %></li> 9 <% end %> 10 </ul> 11 </div> 12 <% end %> 13 14 <div class="field"> 15 <%= form.label :title %> 16 <%= form.text_field :title,:size=>"60" %> 17 </div> 18 19 <div class="field"> 20 <%= form.label :url %> 21 <%= form.text_field :url,:size=>"60" %> 22 </div> 23 24 <div class="actions"> 25 <%= form.submit %> 26 </div> 27<% end %> 28

Model

1class Search < ApplicationRecord 2end 3

現在

現在

やりたいイメージ

ひとつひとつ登録するだと面倒なので、

複数入力してまとめて登録できるようにしたい。
やりたいイメージ

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

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

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

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

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

m.ts10806

2021/01/13 06:19 編集

formのview見た感じ複数レコードないように見えますが、 実際はどのようなデータなのでしょうか。
mbaby__8

2021/01/13 06:34

すみません修正しました。 フォームからタイトルとurlを登録するときに、1つずつではなくまとめて入力して登録したいと思っています。
guest

回答1

0

ベストアンサー

insert_allを使ったことがないのであくまでRailsドキュメントから見るに
Railsドキュメント:insert_all

サンプルコードのように配列+オブジェクト形式の情報を引数にするようなので、

ruby

1Book.insert_all([ 2 { id: 1, title: "Rework", author: "David" }, 3 { id: 1, title: "Eloquent Ruby", author: "Russ" } 4])

これに沿う形のリクエストが送信できれば良いと思います。

各入力内容のname部分を配列にするとかで出来そうです。
参考:formのinput valueを配列で受け取りたい場合のname属性
※3年以上前の記事なのでRails6でそのまま適用できるかは不明ですが、考え方は「配列にする」で間違いないはず

投稿2021/01/13 06:45

m.ts10806

総合スコア80875

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問