在r中连接ROracle时出现无效连接错误

时间:2016-11-18 07:11:34

标签: r roracle

下面是我试图在rstudio中运行并获得以下错误的代码,有人可以指出我的错误:

Warning: Error in .oci.GetQuery: invalid connection Stack trace (innermost first): 84: .oci.GetQuery 83: .local 82: dbGetQuery 81: dbGetQuery 80: getqdata [P:/EI_DBA_Engineering/ShinyR/EI/App5/apptest.r#51] 79: ggplotly [P:/EI_DBA_Engineering/ShinyR/EI/App5/apptest.r#56] 78: func 77: origRenderFunc 76: output$dynamicPlot 1: runApp 下面的代码试图建立与数据库的连接并检索数据,我在连接时遇到错误。

    require(ggplot2)
require(scales)
require(reshape)
require(ROracle)
require(shiny)
library(plotly)
ui <- dashboardPage(
  skin="green",
  dashboardHeader(title = "Real Time Dashboard for EI"),
  dashboardSidebar(disable = TRUE),
  dashboardBody(
    fluidRow(
      # A stati"c valueBox
      #column(5,DT::dataTableOutput("text1"))
    ),
    box(
      title = "CPU UTILIZATION DAILY "
      ,status = "primary"
      ,solidHeader = TRUE
      ,collapsible = TRUE
      ,width = "800px"
      ,plotlyOutput('dynamicPlot', height = "300px")
    )
  ))
server <- function(input, output, session) {
  sqlstmt1 <- reactive({
    sqlstmt1 <- paste0("select instance_name from v$instance")
    print (sqlstmt1)
    return(sqlstmt1)
  })
  con <- reactive({
    drv <- dbDriver("Oracle")
    on.exit(dbDisconnect(con))
    con <- dbConnect(drv, dbname = "abcd", username = "aaaaa", password =  "bbbbbbb")
    print (con)
    return(con)
  })
   getqdata <- function (con) {
    print ("inside get\n")
    #print (con())
    #print (sqlstmt1()) 
    cat("Refreshing....","\n")
    mdat <- dbGetQuery(con,sqlstmt1())
    return(mdat)
  }
  output$dynamicPlot <- renderPlotly({
    p1 <- getqdata(con())
    stout <- t(p1())
    mdata <- melt(p1(), id.var = c("TTIME", "ENTITY_NAME")) 
    print (mdata)
    invalidateLater(10000, session)
    #p1 <- plot_ly(mdata, x = ~TTIME, y = ~value, type = 'scatter', mode = 'lines',  color= ~ENTITY_NAME , fill = 'tozeroy') %>%
     # layout(xaxis = list(title = 'Date',showticklabels = FALSE),
      #     yaxis = list(title = 'CPU Percentage'))
      #ggplotly(p1)
    #invalidateLater(10000, session)
      })
  }
shinyApp(ui, server)

1 个答案:

答案 0 :(得分:2)

我通过取出on.exit(dbDisconnect(con))

解决了这个问题