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

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

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

Ruby on Rails 7は、2021年12月に正式リリースされました。Ruby on Railsのバージョン7であり、フロントエンド開発環境を大幅に刷新。Node.jsを用いない構成がデフォルトになっています。

Q&A

解決済

1回答

248閲覧

DBへのレコードの挿入を1件ずつではなく、重複を避けて一括でまとめて保存する方法

tkshp

総合スコア174

Ruby on Rails 7

Ruby on Rails 7は、2021年12月に正式リリースされました。Ruby on Railsのバージョン7であり、フロントエンド開発環境を大幅に刷新。Node.jsを用いない構成がデフォルトになっています。

0グッド

0クリップ

投稿2023/05/17 12:42

実現したいこと

以下のように複数のbookデータがあり、データベースに当該book_idのレコードがなければ(重複していなければ)、
そのbookデータをデータベースに保存するという処理を行っています。

book_arr = [ {"book_id"=>1, "title"=>"A"}, {"book_id"=>2, "title"=>"B"}, {"book_id"=>3, "title"=>"C"}, ] book_arr.each{|book| unless Book.exist?(book_id: book["book_id"]) b1 = Book.new( book_id: book["book_id"], title: book["title"] ) b1.save end }

これで一応、目的の処理は果たせているのですが、1件1件データベースに接続して保存しているので
効率が悪く、パフォーマンス的にはよくないです(DBの接続は極力少なくしたいです)。
これを一括でまとめて保存するにはどのように実装すればよいでしょうか?

試したこと

調べたところ、以下のようなコードの書き方があるみたいなので、

User.create( [ { name: 'taro', age: 20 }, { name: 'hanako', age: 25 } ] )

この書き方で、以下のようにすればまとめて保存できることはわかりました(実際に確かめました)。

Book.create(book_arr)

しかし、以下のように重複していなければ保存するという書き方がわかりませんでした。

unless Book.exist?(book_id: book["book_id"])

また、さらに調べたところ、以下のような複数の条件も指定できるみたいですが、
1件でもあったら(存在したら)、一切、レコードを挿入しないということをしたいのではなく、
重複するレコードのみ挿入せず、重複しない他のレコードは挿入したいので、この書き方も違うかなと思いました。

User.exists?(id: [1, 2, 3] ) 

そもそもこういった目的の実装は不可能でしょうか?

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

Rails 7.0.4
ruby 3.1.2p20

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

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

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

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

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

guest

回答1

0

ベストアンサー

単純な操作を組み合わせてはどうでしょうか。

  1. Book.pluck(:book_id)で存在するbook_idの値を全部抜き出す
  2. book_arrselectをかけて、book_idが存在しないものを抽出
  3. 一気にcreate

投稿2023/05/18 01:53

maisumakun

総合スコア145183

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

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

tkshp

2023/05/19 03:01

実装できました、ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問