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

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

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

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

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

Q&A

解決済

1回答

1371閲覧

railsのactiverecordで結合した結果を配列として取得したい

keng

総合スコア32

Ruby on Rails 5

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

Active Record

Active Recordは、一つのオブジェクトに対しドメインのロジックとストレージの抽象性を結合するデザインパターンです。

0グッド

0クリップ

投稿2018/02/13 03:16

idnametitleopen_atend_atdetail
1hoge1title12018/01/012018/01/30shousai
1hoge1title12018/02/012018/02/20shousai
1hoge1title12018/03/012018/04/30shousai
1hoge1title12018/05/012018/05/10shousai
1hoge1title12018/10/012019/01/30shousai

データベースから結合した結果、上のような結果が返ってきた時、これを表示しようとすると下記のように全てを取り出さないといけなくて困っています。しかしこれでは上の表のような形で全てが表示されてしまい、実際にはopen_atとend_atだけを配列のような形で取得したいです。どのようにすれば良いのでしょうか。

ruby

1@hoge.each do |h| 2<%= h.name %> 3<%= h.title %> 4<%= h.open_at %> 5<%= h.end_at %><br> 6end

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

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

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

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

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

guest

回答1

0

ベストアンサー

... 全てが表示されてしまい...

返ってきた列をすべて表示する必要はないです。

ruby

1@hoge.each do |h| 2<%= h.open_at %> 3<%= h.end_at %><br> 4end

とすれば、open_at と end_at だけを表示できます。

もちろん activerecord で検索結果の列を必要なものだけにする方法もあります。

  • 特定のフィールドだけを取り出す

https://railsguides.jp/active_record_querying.html#%E7%89%B9%E5%AE%9A%E3%81%AE%E3%83%95%E3%82%A3%E3%83%BC%E3%83%AB%E3%83%89%E3%81%A0%E3%81%91%E3%82%92%E5%8F%96%E3%82%8A%E5%87%BA%E3%81%99

  • pluck

https://railsguides.jp/active_record_querying.html#pluck

投稿2018/02/13 14:39

katoy

総合スコア22324

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問