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

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

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

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

Q&A

解決済

2回答

6741閲覧

rails db:seed してもデータが入らない

Cafemocha

総合スコア37

Ruby on Rails

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

0グッド

0クリップ

投稿2017/07/14 00:48

編集2017/07/14 02:49

###前提・実現したいこと
rails db:seedでデータ挿入を完了させたい。

###発生している問題・エラーメッセージ
CarrierWaveを使ったアップロード機能があり、ファイル名の一覧を初期登録データとしてCSVを作成し、rails db:seedでデータ挿入をしたときに、topic_filesにnameが入らない。

###Topicモデル

Ruby

1class Topic < ApplicationRecord 2 has_many :topic_files 3 accepts_nested_attributes_for :topic_files 4 validates :start_day, :end_day, presence: true 5end

###TopicFileモデル

Ruby

1class TopicFile < ApplicationRecord 2 belongs_to :topic 3 mount_uploader :name, TopicFileUploader 4end

###seeds.rb

Ruby

1CSV.foreach('db/convert_data/topic_files.csv', headers: true) do |row| 2 TopicFile.create!(topic_id: row[0], name: row[1]) 3end

###試したこと
TopicFileモデルのmount_uploader :name, TopicFileUploaderをコメントアウトした上で、rails db:seedするとnameにデータが入ることは確認できました。

コメントアウトせずにnameにデータが入るようにするにはどのようにすればよいでしょうか?

###環境
Mac
Ruby 2.4.0
Rails 5.1.1
RubyMine

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

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

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

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

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

guest

回答2

0

自己解決

自己解決しました。
ファイル群をリポジトリに取り込んでseedsファイルを下記の通り変更しました。

ruby

1CSV.foreach('db/convert_data/topic_files.csv', headers: true) do |row| 2 file_path = "#{Rails.root}/db/convert_data/topic_file/" + row[0].to_s + '/' + row[1].to_s 3 TopicFile.create!(topic_id: row[0], name: open(file_path)) 4end

ホントはリポジトリを汚さず、DBにファイル名だけ登録してS3に繋げたかったのですがわかりませんでした。
上記のコードだと、db:seeds時に裏でS3へのアップロード実行されるのでファイルの数や容量がすごい場合は、タイムアウトでサーバから怒られそうな気がします。

投稿2017/07/25 07:47

Cafemocha

総合スコア37

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

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

0

恐らくですが、carrierwaveを指定したカラムに対しては
Fileのオブジェクト情報を登録する必要があると思います。

ruby

1TopicFile.create!(topic_id: row[0], name: row[1]) 2#=> row[1]がCSVから取得したファイル名?(String)なので 3# (File)openなどでファイルオブジェクト(File)にする。

参考にしたサイト
http://noodles-mtb.hatenablog.com/entry/2013/02/04/015245

投稿2017/07/14 01:53

kd314

総合スコア19

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

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

Cafemocha

2017/07/14 04:30

ありがとうございます。 説明が不足しており申し訳ございません。 初期投入のファイル自体はAmazon S3上にあり、seedでファイル名だけ登録したいのです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問