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

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

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

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

Ruby on Rails

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

Q&A

解決済

1回答

2139閲覧

Railsのorderメソッドの優先順位に関して

_Iwasaki_

総合スコア9

Ruby on Rails 5

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

Ruby on Rails

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

0グッド

0クリップ

投稿2020/11/16 23:33

お世話になります。

RailsでWebアプリを制作しているのですが、
タイトルの箇所で躓いているので質問させていただきます。

Lessonというモデルにlesson_dayというDate型のカラムと、
1時間なら1、2時間なら2と入力できる、integer型のsetというカラムがあるとします。

また、Lessonモデルは
belongs_to :studentとなっています。

年度別かつ月別に、

  1. studentの数を被りがないようにcount
  2. setの合計時間をsum

したいのですが...

1の場合は、

ruby

1Lesson 2 .where(lesson_day: Date.new(2020, 4, 1)..Date.new(2021, 3, 31)) 3 .distinct 4 .group("extract(year from lesson_day)", "extract(month from lesson_day)") 5 .order("extract_year_from_lesson_day") 6 .count(:student_id)

としていて、
{[2020.0, 4.0]=>35, [2020.0, 5.0]=>28, [2020.0, 6.0]=>36, [2020.0, 7.0]=>37, [2020.0, 8.0]=>34, [2020.0, 9.0]=>27, [2020.0, 10.0]=>31, [2020.0, 11.0]=>38, [2020.0, 12.0]=>38, [2021.0, 1.0]=>36, [2021.0, 2.0]=>33, [2021.0, 3.0]=>39}

という風に、日付のソートが効いたデータが得られています。

対して、2の場合は、

ruby

1Lesson 2 .where(lesson_day: Date.new(2020, 4, 1)..Date.new(2021, 3, 31)) 3 .group("extract(year from lesson_day)", "extract(month from lesson_day)") 4 .order("extract_year_from_lesson_day") 5 .sum(:set)

としていて、
{[2020.0, 11.0]=>67, [2020.0, 9.0]=>47, [2020.0, 5.0]=>48, [2020.0, 7.0]=>60, [2020.0, 8.0]=>62, [2020.0, 6.0]=>59, [2020.0, 10.0]=>45, [2020.0, 12.0]=>65, [2020.0, 4.0]=>71, [2021.0, 3.0]=>70, [2021.0, 1.0]=>67, [2021.0, 2.0]=>58}

こちらは、日付のソートが効いていません。

この場合は、どのような問題が考えられるでしょうか?

ご存じの方いらっしゃいましたら、ご教授いただけると幸いです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

日付のソートが効いていません。

いえ、指定したとおりに年だけの条件でソートされています。

投稿2020/11/16 23:47

maisumakun

総合スコア146018

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

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

maisumakun

2020/11/17 00:02

1つ目で月まできれいに並んだのはたまたまです。
_Iwasaki_

2020/11/17 14:03

なるほど!! 1つ目は機能していたので、その可能性は頭になかったです。 年 + 月でソートしたら、うまく機能しました!! ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問