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

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

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

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

Q&A

解決済

2回答

1563閲覧

Rubyのby_monthで1ヶ月のレコードを全て取り出せない

退会済みユーザー

退会済みユーザー

総合スコア0

Ruby

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

0グッド

0クリップ

投稿2016/11/07 15:56

編集2016/11/10 16:33

my_date.by_month(10, year: 2016, field: :date)
という風にすると、2016年の10月というレコード全てを取り出せると思ったのですが、どうやら1日のレコードだけ取り出せません。

1日のレコードが正常に保存されいないのかと思いましたが、my_dateを表示してみると1日のレコードもあります。

by_monthを使って抽出することができません。
原因などわかれば教えていただきたいです。


by_starというgemを使っています。
github.com/radar/by_star

my_dateは変数で、"2016-11-11"などのような値が入ります。


ID|my_date|created_at|updated_at
1|2016-11-01|2016-11-07 14:45:26.837986|2016-11-07 14:45:26.837986

データとしてこのような感じです。このようなデータから絞り込みを行います。
dateの2016/11月で絞り込みをかけた時は1日のみ取得できません。

my_dateとcreated_atの違いとしては、時間の情報があるかないかだけだと思うのですが、それが問題だったりするのでしょうか?

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

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

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

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

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

hana-da

2016/11/07 22:34

情報量が少なすぎます。私の環境で by_month.my_date(10, year: 2016, field: :date) とすると NameError: undefined local variable or method `by_month' for main:Object になります。ruby標準ではby_monthというメソッドもmy_dateというメソッドもありません。どんなライブラリ(gem)をつかっているのかなど詳細に書いてください。
guest

回答2

0

ベストアンサー

my_dateはdate型で、created_atなどはdatetaime型でした。
どうやらこれが原因で一日が取得できなかったようです。
my_dateをdatetime型に変更すると正常に日付の取得が行えました。

投稿2016/11/11 04:08

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

my_dateは変数で、"2016-11-11"などのような値が入ります。

my_dateが変数で文字列(String)が入っているのであれば my_date(10, year: 2016, field: :date) のような記述は NoMethodError: undefined method `my_date' となるはずですが。。。

とりあえず my_date のところはスルーして by_star gem について書くと

ruby

1model_instance.by_month(10, year: 2016, field: :date)

という書き方になると思います(model_instanceの部分は例なので適切に書き換えてください)

投稿2016/11/09 00:46

hana-da

総合スコア1728

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

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

退会済みユーザー

退会済みユーザー

2016/11/10 16:19

申し訳ないです。my_date.by_monthでした。 ``` model_instance.by_month(10, year: 2016, field: :date) ``` という書き方をしているのですが、やはり1日のデータが取れないようです。 gem以外に問題があるという風に考えて妥当でしょうか?
hana-da

2016/11/10 22:15

質問に記載されている内容に多々矛盾が生じているので検証できず断定はできないですが、99% gemに問題はなく、使い方が間違えていると思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問