0

我正在尝试从 AWS SQL Server 获取数据。此代码在本地 PC 上运行良好,但在闪亮服务器(ubuntu)上不起作用。

library(dbplyr)
library(dplyr)
library(DBI)    

con <- dbConnect(odbc::odbc(),
                 driver = "FreeTDS",
                 server = "aws server",
                 database = "",
                 uid = "",
                 pwd = "")
tbl(con, "shops")
dbGetQuery(con,"SELECT *
                  FROM shops")

"R version 3.4.2 (2017-09-28)"

packageVersion("dbplyr")
[1] ‘1.2.1.9000’

packageVersion("dplyr")
[1] ‘0.7.4’
packageVersion("DBI")
[1] ‘0.7.15’

我有下一个错误:

tbl(con, "shops")
Error: <SQL> 'SELECT *
FROM "shops" AS "zzz2"
WHERE (0 = 1)'
  nanodbc/nanodbc.cpp:1587: 42000: [FreeTDS][SQL Server]Incorrect syntax near 'shops'. 

dbGetQuery(con,"SELECT * FROM shops")工作正常。你能解释一下出了什么问题吗?

4

1 回答 1

1

这更有可能是因为 FreeTDS 驱动程序不返回class期望dbplyr看到的以使用 MS SQL 翻译。解决方法是获取结果,class(con)然后在连接后立即添加以下行,但在调用tbl(). 将 替换为调用[you class name]结果:class(con)

sql_translate_env.[your class name] <- dbplyr:::`sql_translate_env.Microsoft SQL Server`
sql_select.[your class name]<- dbplyr:::`sql_select.Microsoft SQL Server`
于 2018-04-18T23:25:54.220 回答