Предположим, у нас есть таблица с именем Activities
+-----------+-----------+------------+--------------+
| player_id | device_id | event_date | games_played |
+-----------+-----------+------------+--------------+
| 1 | 2 | 2016-03-01 | 5 |
| 1 | 2 | 2016-05-02 | 6 |
| 2 | 3 | 2017-06-25 | 1 |
| 3 | 1 | 2016-03-02 | 0 |
| 3 | 4 | 2018-07-03 | 5 |
+-----------+-----------+------------+--------------+
Я хочу узнать player_id
, и это first event_date
как first_date.
SQL:
SELECT Activities.player_id, min(Activities.event_date) as first_date
FROM `activities`
GROUP BY `activities`.`player_id`
Таблица результатов:
+-----------+-------------+
| player_id | first_login |
+-----------+-------------+
| 1 | 2016-03-01 |
| 2 | 2017-06-25 |
| 3 | 2016-03-02 |
+-----------+-------------+
Как это сделать в Rails?
Я пробовал это, но получил коллекцию Activity
, которая содержит только player_id
.
Activity.select('Activities.player_id, min(Activities.event_date) as first_date')
.group(:player_id)
Как это
[#<Activity:0x00007f94923bb888 player_id: 1>, #<Activity:0x00007f94923bb608 player_id: 2>, #<Activity:0x00007f94923b9ba0 player_id: 3>]