ECサイトのようなRailsアプリの機能の1つとして、登録されているユーザー情報のcsv出力機能を実装しようとしています。
出力したいcsvデータとして
①ユーザーテーブルの情報
②ユーザーごとの注文回数(ユーザー:注文 = 1:N)
を出力したいです。
①は取り出せたのですが、他テーブルとなる注文テーブルの情報を扱うことができず困っています。
ユーザーモデル内にcsv出力の記述を行なっており、csv出力記述の前にユーザーテーブルと注文テーブルを結合する処理を書いたのですが、欲しい値が取り出せません。
【現在のソース】
app > views > users >index.html.rb
・ ・ #csv出力ボタン <%= link_to "エクスポート", users_path(format: :csv), class: "btn btn-primary mb-3" %> ・ ・
app > controllers > users_controller.rb
・ ・ def index @users = User.all.order("created_at DESC").page(params[:page]) respond_to do |format| format.html format.csv { send_data @users.generate_csv, filename: "users-#{Time.zone.now.strftime("%Y%m%d%S")}.csv" } end end ・ ・
app > models > users.rb
def created_at_date#出力時の日付フォーマットを整える created_at.strftime('%Y/%m/%d') end def updated_at_date#出力時の日付フォーマットを整える updated_at.strftime('%Y/%m/%d') end def self.csv_attributes #出力の前準備用の記述だがここの書き方がよくわかっていない・・・ order_counts = self.joins( "LEFT OUTER JOIN orders ON users.id = orders.user_id" ).select("orders.*").where(order_completed: true).count ["name", "tel", "email", "post_code", "prefectures", "address_1", "address_2", "room_number", "created_at_date", "updated_at_date", "orders_counts"] end def self.generate_csv csv_columns = ["名前", "電話番号", "メールアドレス", "郵便番号", "都道府県", "住所1", "住所2", "住所3", "登録日時", "最終更新日時", "総依頼回数"] CSV.generate(headers: true) do |csv| csv << csv_columns # csv << csv_attributes all.each do |user| csv << csv_attributes.map{ |attr| user.send(attr) } end end end
ユーザーテーブルと注文テーブルを結合し、注文完了(order_completed: true)している注文情報をcountで集計しようとしているのですが書き方が異なっているせいか取り出せません。
出力したcsvの該当レコードには「<Order::ActiveRecord_Associations_CollectionProxy:~」と表記されています。
関連テーブルに関わる情報のCSV出力方法についてアドバイスいただけると助かります。
よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/08/14 01:00 編集
2020/08/14 05:03
2020/08/14 05:11
2020/08/14 08:00