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

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

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

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

Ruby on Rails

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

Q&A

解決済

1回答

1767閲覧

Rails で 1年間分のレコードを取り出す方法を教えてください。

koume

総合スコア458

Ruby

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

Ruby on Rails

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

0グッド

0クリップ

投稿2018/03/14 08:09

編集2018/03/14 08:17

Rails5.1.3でWebアプリケーション制作の勉強をしています。
レコードの取り出し方法ですが今月より1年間のレコードを取り出すにはどうすればいいのでしょうか?
サイトで調べていたら以下のようなコードを見つけましたが上手く取り出せませんでした。

from = Time.zone.now.at_beginning_of_day to = (from + 1.year) items = Customer.where(created_at: from...to)

これをコンソールで実行してみました。

irb(main):006:0> from = Time.zone.now.at_beginning_of_day => Wed, 14 Mar 2018 00:00:00 JST +09:00 irb(main):007:0> to = (from - 1.year) => Thu, 14 Mar 2017 00:00:00 JST +09:00 irb(main):008:0> items = Customer.where(created_at: from...to) (0.4ms) SELECT `customers`.`id` FROM `customers` (1.0ms) SELECT `customers`.`nickname` FROM `customers` Customer Load (1.4ms) SELECT `customers`.* FROM `customers` WHERE (`customers`.`created_at` >= '2018-03-14 00:00:00' AND `customers`.`created_at` < '2017-03-14 00:00:00') LIMIT 11 => #<ActiveRecord::Relation []>

うまくできませんでした。

Customerテーブルで今月から1年間分さかのぼって登録されたレコードを全て取得したいのです。

どなたか教えていただけないでしょうか?宜しくお願いします。

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

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

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

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

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

guest

回答1

0

自己解決

abc = Customer.where(created_at: to..form)で取得できました。
to..formの部分に記述ミスがありました。

投稿2018/03/14 09:38

koume

総合スコア458

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問