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

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

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

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

Ruby on Rails 4

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

Q&A

1回答

631閲覧

特定のテーブルデータを日毎に集計したい

begenner

総合スコア79

Ruby

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

Ruby on Rails 4

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

0グッド

1クリップ

投稿2019/02/24 09:25

現在当月の日毎に合計金額を集計する処理をしたいのですが
うまくいきません(m_ m)
わかる方がいらっしゃれば教えていただきますようよろしくお願いいたします(m
_m)

###エラー内容

bash

1 2ActiveRecord::StatementInvalid in ChartSampleController#index 3Mysql2::Error: Column 'created_at' in where clause is ambiguous: SELECT SUM(`orders`.`amount`) AS sum_amount, DAY(orders.created_at) AS day_orders_created_at FROM `orders` LEFT OUTER JOIN `users` ON `users`.`id` = `orders`.`user_id` LEFT OUTER JOIN `addresses` ON `addresses`.`id` = `orders`.`address_id` LEFT OUTER JOIN `cartitems` ON `cartitems`.`order_id` = `orders`.`id` LEFT OUTER JOIN `items` ON `items`.`id` = `cartitems`.`item_id` WHERE (created_at >= '2019-02-01 00:00:00.000000') GROUP BY DAY(orders.created_at)

###期待する動作

  • ordersテーブルのレコードのamountカラム(合計金額)を日毎に集計したい

###動作環境
Ruby:2.4.5
Ruby on Rails: 4.2.11
MySQL: 5.7.18

###参考サイト
【Rails】ActiveRecordで、月ごと年ごとの合計 - Qiita
###試したこと
.sum(:amount)の部分を.sum(:orders.amount)としてみましたがダメでした
###補足情報
下記のordersは後で使いまわせるようにできるだけそのままでお願いしたいです
(includesの書き方が違う場合はご指摘お願いいたします)
イメージ説明
###該当のソースコード

ruby

1#app/controllers/chart_sample_controller.rb 2 def index 3 t = Time.current 4 orders= Order.includes([:user, :address, cartitems: :item]).where('created_at >= ?', t.beginning_of_month) 5 @sales_per_day =orders.group("DAY(orders.created_at)").sum(:amount) 6 end

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

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

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

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

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

guest

回答1

0

Column 'created_at' in where clause is ambiguous

っていう英語を訳してくれっていう質問でしたらGoogle翻訳でも使ってみて下さい。

created_atがいろんなテーブルにあるので、「どのテーブルのcreated_atかわかんねーよ」って怒ってるんですよ。

投稿2019/02/24 10:39

kunai

総合スコア5405

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問