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

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

新規登録して質問してみよう
ただいま回答率
85.50%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

RubyGems

RubyGemsはRubyによるプログラミングのためのパッケージマネジメントツールです。ユーザはこれを使用することで、Rubyライブラリのダウンロードやアップデートや、依存関係の自動解決が可能になります。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

Q&A

解決済

2回答

9847閲覧

[Rails] activerecord-importを使用したバルクインサートで親子モデルの同時保存

yuukive

総合スコア40

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

RubyGems

RubyGemsはRubyによるプログラミングのためのパッケージマネジメントツールです。ユーザはこれを使用することで、Rubyライブラリのダウンロードやアップデートや、依存関係の自動解決が可能になります。

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

1グッド

0クリップ

投稿2016/06/23 07:05

編集2016/06/23 07:13

###前提・実現したいこと
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')

miyamiya👍を押しています

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

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

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

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

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

guest

回答2

0

ベストアンサー

activerecord-import
では子レコードも同時にインサートできますが
できるのはPosgreSQLだけなんですねLogをよむとわかります。
MySQLではできません。
うろ覚えですがそもそも
Mysqlの複数インサートではIDの戻り値を紐づけることができなかったと思います。
なので、方法としては、osgreSQLに変えるか
トランザクションをロックして、IDをあらかじめ紐付けして両方に入力してから
それぞれバルクインサートしてください

投稿2016/12/14 02:10

moke

総合スコア2241

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

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

yuukive

2016/12/14 18:29

> トランザクションをロックして、IDをあらかじめ紐付けして両方に入力してから > それぞれバルクインサートしてください やっぱりMySQLでは自力でID紐付けるしか無いんですね…ありがとうございます。
guest

0

バルクインサートができるかわかりませんが、関連dbを更新するのには、Nested Form Gemが便利です。
参考

投稿2016/12/14 01:44

NishidaRyu416_

総合スコア113

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問