У меня есть таблица user_profile_view:
Определение выглядит следующим образом:
+------------+------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+------------+------------+------+-----+---------+----------------+
| id | bigint(20) | NO | PRI | NULL | auto_increment |
| user_id | bigint(20) | NO | MUL | NULL | |
| viewer_id | bigint(20) | NO | MUL | NULL | |
| created_at | datetime | NO | | NULL | |
| updated_at | datetime | NO | | NULL | |
+------------+------------+------+-----+---------+----------------+
Я пытаюсь получить самые последние посещения, но хочу отобразить пользователя только один раз
Простой запрос, такой как этот, вернет самые последние посещения профиля:
SELECT v.* FROM user_profile_view v
WHERE v.user_id != 1 AND v.viewer_id = 1
ORDER BY created_at DESC LIMIT 0,10;
Набор результатов:
+-----+---------+-----------+---------------------+---------------------+
| id | user_id | viewer_id | created_at | updated_at |
+-----+---------+-----------+---------------------+---------------------+
| 946 | 19 | 1 | 2011-10-05 19:20:19 | 2011-10-05 19:20:19 |
| 945 | 19 | 1 | 2011-10-05 19:16:15 | 2011-10-05 19:16:15 |
| 944 | 2 | 1 | 2011-10-05 19:12:02 | 2011-10-05 19:12:02 |
| 943 | 13 | 1 | 2011-10-05 19:11:45 | 2011-10-05 19:11:45 |
| 942 | 19 | 1 | 2011-10-05 19:10:41 | 2011-10-05 19:10:41 |
| 941 | 2 | 1 | 2011-10-05 19:06:35 | 2011-10-05 19:06:35 |
| 940 | 19 | 1 | 2011-10-05 18:53:04 | 2011-10-05 18:53:04 |
| 939 | 19 | 1 | 2011-10-05 18:51:56 | 2011-10-05 18:51:56 |
| 938 | 19 | 1 | 2011-10-05 18:46:59 | 2011-10-05 18:46:59 |
| 937 | 20 | 1 | 2011-10-05 18:42:35 | 2011-10-05 18:42:35 |
+-----+---------+-----------+---------------------+---------------------+
Однако я хочу только вернутьпользователь один раз .Поэтому, если я недавно просматривал профиль пользователя 3 раза, мне нужно только самое последнее посещение этого профиля, а затем отобразить следующего пользователя, которого я посетил ранее.
Это должно быть тривиально, но по какой-то причине язастрял.
Спасибо, ребята!