這是 tidyr uncount()
泛型的方法。它使用臨時表,因此您的數據庫用戶需要創建臨時表的權限。
參數
- data
-
由數據庫查詢支持的惰性 DataFrame 。
- weights
-
權重向量。在
data
上下文中評估;支持準引號。 - .remove
-
如果
TRUE
和weights
是data
中的列名稱,則刪除該列。 - .id
-
提供一個字符串來創建一個新變量,該變量為每個創建的行提供唯一的標識符。
例子
df <- memdb_frame(x = c("a", "b"), n = c(1, 2))
dbplyr_uncount(df, n)
#> # Source: SQL [3 x 1]
#> # Database: sqlite 3.41.2 [:memory:]
#> x
#> <chr>
#> 1 a
#> 2 b
#> 3 b
dbplyr_uncount(df, n, .id = "id")
#> # Source: SQL [3 x 2]
#> # Database: sqlite 3.41.2 [:memory:]
#> x id
#> <chr> <int>
#> 1 a 1
#> 2 b 1
#> 3 b 2
# You can also use constants
dbplyr_uncount(df, 2)
#> # Source: SQL [4 x 2]
#> # Database: sqlite 3.41.2 [:memory:]
#> x n
#> <chr> <dbl>
#> 1 a 1
#> 2 b 2
#> 3 a 1
#> 4 b 2
# Or expressions
dbplyr_uncount(df, 2 / n)
#> # Source: SQL [3 x 2]
#> # Database: sqlite 3.41.2 [:memory:]
#> x n
#> <chr> <dbl>
#> 1 a 1
#> 2 b 2
#> 3 a 1
相關用法
- R dbplyr dbplyr-slice 使用行的位置對行進行子集化
- R dbplyr db-quote SQL 轉義/引用泛型
- R dbplyr distinct.tbl_lazy 子集不同/唯一行
- R dbplyr backend-teradata 後端:Teradata
- R dbplyr escape 轉義/引用字符串。
- R dbplyr expand.tbl_lazy 擴展 SQL 表以包含所有可能的值組合
- R dbplyr backend-sqlite 後端:SQLite
- R dbplyr pivot_wider.tbl_lazy 將數據從長軸轉向寬軸
- R dbplyr build_sql 構建 SQL 字符串。
- R dbplyr mutate.tbl_lazy 創建、修改和刪除列
- R dbplyr collapse.tbl_sql 計算查詢的結果
- R dbplyr sql_expr 從 R 表達式生成 SQL
- R dbplyr get_returned_rows 提取並檢查返回的行
- R dbplyr count.tbl_lazy 按組計數觀察值
- R dbplyr backend-odbc 後端:ODBC
- R dbplyr head.tbl_lazy 對第一行進行子集化
- R dbplyr copy_inline 在 dbplyr 查詢中使用本地 DataFrame
- R dbplyr backend-oracle 後端:甲骨文
- R dbplyr backend-snowflake 後端:雪花
- R dbplyr lahman 緩存並檢索 Lahman 棒球數據庫的 src_sqlite。
- R dbplyr backend-redshift 後端:紅移
- R dbplyr partial_eval 部分評估表達式。
- R dbplyr group_by.tbl_lazy 按一個或多個變量分組
- R dbplyr tbl_lazy 創建本地惰性 tibble
- R dbplyr backend-hana 後端:SAP HANA
注:本文由純淨天空篩選整理自Hadley Wickham等大神的英文原創作品 "Uncount" a database table。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。