使用 memdb 和 dbplyr 设置覆盖 == TRUE

Posted

技术标签:

【中文标题】使用 memdb 和 dbplyr 设置覆盖 == TRUE【英文标题】:Setting overwrite == TRUE using memdb and dbplyr 【发布时间】:2020-04-22 18:57:55 【问题描述】:

以下闪亮的应用程序在您第一次运行时可以运行,但如果您更改物种输入,则会出错,因为表名已存在于内存中。我想知道如何根据下面的代码设置覆盖 == TRUE?

library(shiny)
library(tidyverse)
library(dbplyr)

ui <- fluidPage(
    selectInput("species", "Species", choices = unique(iris$Species), 
                selected = "setosa"),
    tableOutput("SQL_table"),
    actionButton("code", "View SQL"),
)


server <- function(input, output) 

    # render table
    output$SQL_table <- renderTable(
        head(iris %>% filter(Species == input[["species"]]))
    )

    # generate query
    SQLquery <- reactive(
        sql_render(
            show_query(
                tbl_memdb(iris) %>%
                filter(Species == local(input$species))
            )
        )
    )

    # see query
    observeEvent( input$code, 
        showModal(
            modalDialog(
                SQLquery()
            )
        )
    )



shinyApp(ui = ui, server = server)

【问题讨论】:

【参考方案1】:

由于memdb_frame只是copy_to的函数调用,我们可以直接用它来设置overwrite = TRUE

copy_to(src_memdb(), iris, name = 'iris', overwrite=TRUE)

【讨论】:

嘿@MayaGans,那我该如何建立到这个远程表的连接或删除它?

以上是关于使用 memdb 和 dbplyr 设置覆盖 == TRUE的主要内容,如果未能解决你的问题,请参考以下文章

从 dbplyr 中的给定 SQL 查询开始使用 dbplyr

go-memdb

一年中的一周使用 bigquery / bigrquery 和 dbplyr? (相当于 lubridate::week)

在 SQL Server 中结合 dbplyr 和 case_when

max(.) 中的错误:使用 dplyr dbplyr 和 bigrquery 时参数的“类型”(列表)无效

使用 dbplyr 跨数据库连接