Я пытаюсь получить данные с сервера MS SQL в блестящем приложении. Я использую пакет odb
c версии 1.2.2. Когда я запускаю приложение локально, я могу получить данные, и все в порядке. Но на сервере у меня появляется следующая ошибка:
Listening on http://127.0.0.1:5823
Warning in connection_release(conn@ptr) :
There is a result object still in use.
The connection will be automatically released when it is closed
Warning: Error in : <SQL> 'select Parameter.name,ParamValue.value
from Parameter
inner join ParamValue on Parameter.id = ParamValue.parameterId
where Parameter.name = 'airDensity'order by Parameter.name'
nanodbc/nanodbc.cpp:1587: 42000: [FreeTDS][SQL Server]Unicode data in a Unicode-only collation or ntext data cannot be sent to clients using DB-Library (such as ISQL) or ODBC version 3.7 or earlier.
81: <Anonymous>
Ниже приведена краткая версия моего приложения.
library(shiny)
ui <- fluidPage(
withMathJax(),
tabsetPanel(
tabPanel("Help Page",
h2(HTML("<ul> <b>How to use the tool</b></ul>"))
),
tabPanel("LCA",
dashboardPage(skin = "green",
dashboardHeader(title = "LCA Database"),
dashboardSidebar(
tags$a(href = "https://www.xxxxxxxxx.com/en-int", tags$img(src='SG_logo_neg_rgb.png', height = 70, width = 230)),
tags$hr(),
selectInput("t1","Select Parameter", choices = c("Param")),
selectInput("t2","Select Parameter", choices = c("-"))
),
dashboardBody(
)
)
)
)
)
и сервера:
library(shiny)
library(odbc)
library(dbplyr)
server <- function(input, output, session){
main <- reactive({
con <- dbConnect(odbc(),
Driver = "libtdsodbc.so",
Server = "xxxxx.xxxxxx.xxxxx",
Database = "LCA",
UID = "LCA-User",
PWD = "xxxxxxxxxxxxxx",
encoding = "windows-1252",
Port = 1433)
on.exit(odbc::dbDisconnect(con))
squery = dbSendQuery(con,"select name from Parameter order by name",stringsAsFactors = FALSE)
parameterNmaes = dbFetch(squery )
result= list(parameterNmaes = parameterNmaes)
return(result)
})
# updating the first dropdown
observeEvent(main(),{
updateSelectInput(session, "t1",
choices = main()$parameterNmaes)
})
# second dropdown based on user selection
subselect1 <- reactive({
con <- dbConnect(odbc(),
Driver = "libtdsodbc.so",
Server = "xxxx.xxxxx.xxxx",
Database = "LCA",
UID = "LCA-User",
PWD = "xxxxxxxxxxxxxx",
encoding = "windows-1252",
Port = 1433)
on.exit(odbc::dbDisconnect(con))
squery = dbSendQuery(con,paste0("select Parameter.name,ParamValue.value
from Parameter
inner join ParamValue on Parameter.id = ParamValue.parameterId
where Parameter.name = '",input$t1,"'order by Parameter.name"),stringsAsFactors = FALSE)
p = dbFetch(squery )
p1 = p %>%
mutate(deserial = lapply(p[,2], mType))%>%
mutate(numericValue = sapply(lapply(deserial, deserialize),`[`, "v"))
res = sort(as.character(unique(p1$numericValue)))
result= list(res = res, p1 = p1)
return(result)
})
observeEvent(subselect1(),{
updateSelectInput(session, "t2",
choices = subselect1()$res)
})
}