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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

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

Q&A

解決済

1回答

1370閲覧

【rails】 csvファイルをseeds.rbを使ってデータベースに取り込みたい

kawanoonigiri

総合スコア14

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails 6

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

0グッド

0クリップ

投稿2021/09/03 03:17

前提・実現したいこと

rails初学者です。
現在作成しているアプリケーションのローカル環境で、csvファイルとseeds.rbファイルを使った初期データを反映したいのですが、ターミナルでrails db:seedをしてもデータが反映されません。

該当のソースコード

seeds.rb

ruby

1require "csv" 2 3CSV.foreach('db/csv/store_data.csv',headers: true) do |row| 4 Store.create( 5 name: row['name'], 6 address: row['address'], 7 postal_code: row['postal_code'], 8 telephone: row['telephone'], 9 url: row['url'], 10 closing_day: row['closing_day'], 11 business_hour: row['business_hour'], 12 fee: row['fee'], 13 parking_car: row['parking_car'], 14 parking_bicycle: row['parking_bicycle'], 15 towel_rental: row['towel_rental'], 16 water: row['water'], 17 water_depth: row['water_depth'], 18 water_quality: row['water_quality'], 19 temperature: row['temperature'], 20 roryu_status: row['roryu_status'], 21 roryu_time: row['roryu_time'], 22 air_bath: row['air_bath'], 23 break_place: row['break_place'], 24 television: row['television'], 25 bgm: row['bgm'], 26 user_id: row['user_id'] 27 ) 28end 29

補足情報

ターミナル上でrails db:seedを実行したところ、エラー文も何もでずそのまま入力待機状態に戻ります。

情報不足しているようでしたら追記いたします。
お詳しい方いらっしゃいましたらご教授いただけますと助かります。

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

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

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

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

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

guest

回答1

0

ベストアンサー

seeds.rb の Store.createStore.create! にして rails db:seed を実行してみましょう。
作成できないとエラーが発生し、エラーメッセージからその原因が分かるかもしれません。

投稿2021/09/03 03:41

neko_daisuki

総合スコア2090

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

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

kawanoonigiri

2021/09/03 03:47 編集

コメントありがとうございます。 Store.create!に変更したところ下記エラー文が出ました。 rails aborted! ActiveRecord::RecordInvalid: Validation failed: Images can't be blank /Users/yyyyxxxx/original/SENTO/db/seeds.rb:4:in `block in <main>' /Users/yyyyxxxx/original/SENTO/db/seeds.rb:3:in `<main>' /Users/yyyyxxxx/original/SENTO/bin/rails:9:in `<top (required)>' /Users/yyyyxxxx/original/SENTO/bin/spring:15:in `<top (required)>' bin/rails:3:in `load' bin/rails:3:in `<main>' Tasks: TOP => db:seed
neko_daisuki

2021/09/03 03:53

images が空なので作成できないみたいですね。 たしかにcreateの中でimagesは指定されていません。 (A) create のときに images を指定する (B) app/models/store.rb に validates :images, presence: true とあると思うので それを消す(本当に消して良いのかは私には分かりません)
kawanoonigiri

2021/09/03 04:49

ご対応ありがとうございます。 強引ではありますが、(B)案にて無事データを反映できました。 imagesの反映も同時にできないか、調べながらチャレンジしてみます。 素早いご回答、誠にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問