###前提・実現したいこと
has_many/belongs_to関係にある親子テーブルを、バルクインサートで同時に保存したいです。
→現状はactiverecord-import GEMを使用していますが、バルクインサートの目的が
達成できればGEM使用有無は問いません。
###発生している問題・エラーメッセージ
以下コード実行時に親しか保存されず、保存時にエラーメッセージも表示されないため困っています…
###該当のソースコード
実際のコードとは違うのですが、簡略化したものは以下のとおりとなります。
ruby
1# Book has_many authors / Author belongs to Book という関係になっています。 2books = [] 310000.times do |i| 4 book = Book.new(:name => "book #{i}") 5 book.author.build(:name => "author #{i}") 6 books << book 7end 8Book.import books, recursive: true 9
###試したこと
activerecord-importにはrecursiveオプションがあり、これをtrueにすることで
子モデルも一緒にINSERTされるはずなのですが、オプションの有無関わらず親しか保存されません。
(保存時にエラーは特に表示されません)
また、booksとは別にauthorsという配列を作り、Book保存後にAuthor.imoport authors
として
別々に保存することも試みたのですが、結局Book.importを使ってbookを保存した後に
それぞれのbookのidが分からず、authoerとのリレーションをキープできずに断念しました。
GEM使用有無にかかわらず、なんとか親子同時にバルクインサートできないでしょうか。
###補足情報(言語/FW/ツール等のバージョンなど)
Ruby on Rails 4.1.5
activerecord-import 0.12.0
MySQL2 ('mysql2' '0.3.16')
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/12/14 18:29