Я хотел бы использовать _1 _ / _ 2_ для создания агрегированной переменной на уровне группы. Вот суть команды:
q = tbl_copy %>%
group_by(group_var) %>%
mutate(x_agg = min(x))
Но это приводит к следующей ошибке: Error: Window function `min()` is not supported by this database
Как ни странно, когда я использую глагол summarise()
, min()
работает нормально.
q = tbl_copy %>%
group_by(group_var) %>%
summarise(x_agg = min(x))
q %>% show_query()
<SQL>
SELECT `group_var`, `x`, MIN(`x`) AS `x_agg`
FROM `my_table`
GROUP BY `group_var`
Что мне не хватает? Как использовать group_by()
с mutate()
в копии таблицы MySQL?
ОБНОВЛЕНИЕ: ВОСПРОИЗВОДИМЫЙ ПРИМЕР
> con <- DBI::dbConnect(RSQLite::SQLite(), ":memory:")
> copy_to(con, mtcars)
>
> mtcars2 <- tbl(con, "mtcars")
> mtcars2 %>%
+ select(mpg,cyl) %>%
+ group_by(cyl) %>%
+ mutate(mpg_min = min(mpg))
Error: Window function `min()` is not supported by this database