Получить переменную MIN Date на основе маркера в строке - PullRequest
1 голос
/ 09 июля 2020

Я использую MySQL с phpMyAdmin, ниже моя таблица данных:

+--------+---------+-----------------+
| userID | context |      time       |
+--------+---------+-----------------+
|    111 |         | 7/1/2021        |
|    111 |         | 7/16/2019       |
|    111 | Reset   | 7/15/2019       |
|    222 |         | 7/9/2020        |
|    222 | Reset   | 7/8/2020        |
|    333 | Reset   | 5/11/2020       |
|    333 |         | 5/10/2020       |
|    444 |         | 9/8/2020        |
+--------+---------+-----------------+

Я ищу запрос SELECT, который дает мне MIN время больше или равняется дате, когда Reset регистрируется в столбце context. Если в столбце context нет маркера Reset , я бы хотел, чтобы результат был включен.

Итак, для приведенной выше таблицы я ожидаю результат:

+--------+-----------------+
| userID |      time       |
+--------+-----------------+
|    111 | 7/15/2019       |
|    222 | 7/8/2020        |
|    333 | 5/11/2020       |
|    444 | 9/8/2020        |
+--------+-----------------+

Я пробовал:

SELECT * FROM foo as a 
WHERE ((SELECT MIN(a.time) FROM foo) >= (SELECT Max(a.time) FROM foo where context = 'Reset')) group by userID

не дает ожидаемого результата, но возвращает:

+--------+-----------+
| userID |   time    |
+--------+-----------+
|    111 | 7/1/2021  |  <--- wrong 
|    222 | 7/8/2020  |
|    333 | 5/11/2020 |
+--------+-----------+

Ответы [ 2 ]

2 голосов
/ 09 июля 2020

Использовать оконные функции:

select t.*,
       coalesce(next_time, time) as imputed_time
from (select t.*,
             sum(context = 'reset') over (partition by user_id) as cnt_reset,
             min(case when context is null then time end) over (partition by userid order by time rows between current row and unbounded following) as next_time
      from t
     ) t
where cnt_reset = 0 or context = 'reset';
1 голос
/ 09 июля 2020

Исходя из ожидаемого результата, вы можете попробовать запрос ниже -

SELECT userID, MAX(time)
  FROM YOUR_TABLE
 WHERE context = 'RESET'
 GROUP BY userID
 UNION ALL
SELECT userID, MAX(time)
  FROM YOUR_TABLE
 WHERE context IS NULL
 GROUP BY userID
 ORDER BY userID
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...