5

我在 R 中建立了一个连接:

conn <- dbConnect(odbc::odbc(),
                 Driver = "SQL Server",
                 Server = "...",
                 Database = "AdventureWorks2012")

默认的 ODBC 驱动程序是 AdventureWorks2012。我可以很好地看到数据集,例如,以下代码运行没有问题:

dbGetQuery(conn, "SELECT TOP 10 * FROM Person.Person")

另一方面,跑步

dbReadTable(conn, "Person.Person")

产量:

Error: <SQL> 'SELECT * FROM "Person.Person"'
  nanodbc/nanodbc.cpp:1587: 42S02: [Microsoft][ODBC SQL Server Driver][SQL Server]Invalid object name 'Person.Person'. 

同样,运行

data <- tbl(conn, "Person.Person")

产量:

Error: <SQL> 'SELECT *
FROM "Person.Person" AS "zzz12"
WHERE (0 = 1)'
  nanodbc/nanodbc.cpp:1587: 42S02: [Microsoft][ODBC SQL Server Driver][SQL Server]Invalid object name 'Person.Person'.

另外,我很困惑WHERE (0 = 1):无法弄清楚它来自哪里!

(1) 该表确实存在于数据库中。(2) 我用正确的 Schema 限定了名称。(3) 我已将 ODBC 中的默认数据库设置为 AdventureWorks2012。

我将感谢您的帮助和洞察力。谢谢你 ...

> tableList <- dbListTables(conn)
> tableList
  [1] "AWBuildVersion"                                      
  [2] "DatabaseLog"                                         
  [3] "DeleteExample"                                       
  [4] "EmployeeSales"                                       
  [5] "ErrorLog"                                            
  [6] "PersonCross"                                         
  [7] "PhoneCross"                                          
  [8] "Department"                                          
  [9] "Employee"                                            
 [10] "EmployeeDepartmentHistory"                           
 [11] "EmployeePayHistory"                                  
 [12] "JobCandidate"                                        
 [13] "Shift"                                               
 [14] "Address"                                             
 [15] "AddressType"                                         
 [16] "BusinessEntity"                                      
 [17] "BusinessEntityAddress"                               
 [18] "BusinessEntityContact"                               
 [19] "ContactType"                                         
 [20] "CountryRegion"                                       
 [21] "EmailAddress"                                        
 [22] "Password"                                            
 [23] "Person"                                              
 [24] "PersonPhone"
 ...

> dbReadTable(conn, "Person")
Error: <SQL> 'SELECT * FROM "Person"'
  nanodbc/nanodbc.cpp:1587: 42S02: [Microsoft][ODBC SQL Server Driver][SQL Server]Invalid object name 'Person'. 
4

3 回答 3

2

我遇到了同样的问题,并在 dbplyr 文档中找到了答案:

https://db.rstudio.com/best-practices/schema/其中包含此错误消息并说您必须这样做:tbl(con, in_schema("production", "flights"))

但是,此处的“生产”特定于您的数据库。

我花了一段时间才弄清楚我的模式名称是什么,但事实证明它只是数据库的名称。所以,也许你可以试试

    conn <- dbConnect(odbc::odbc(),
             Driver = "SQL Server",
             Server = "...",
             Database = "AdventureWorks2012")
    data <- tbl(conn, in_schema("AdventureWorks2012", "Person"))

或者

    data <- tbl(conn, in_schema("Person", "Person"))

?

于 2019-01-08T19:16:51.367 回答
1

由于AdventureWorks不维护任何默认架构(即 no dbo),因此请考虑使用以正确选择此Git 问题评论odbc::dbId中所示的架构下的表:

conn <- dbConnect(odbc::odbc(),
                  Driver = "SQL Server",
                  Server = "...",
                  Database = "AdventureWorks2012")

tbl <- dbId(conn, "Contact", "Person")
dbReadTable(conn, tbl)

注意:对于最近 15 天前odbc的一位作者来说,对模式的支持相对较新。如果 CRAN 版本太旧,您可能需要重新安装 Git 开发版本。

于 2018-04-04T21:10:32.583 回答
0

我发现当我使用带有“Initial Catalogue=dbname”设置而不是“Database=dbname”的连接字符串时出现此错误:

# This works
connectionString <- "Driver={ODBC Driver 17 for SQL Server};Server=tcp:dbServer,1433;Database=dbName;Persist Security Info=False;UID=dbUser;PWD=dbPassword;MultipleActiveResultSets=False;Connection Timeout=30;"

conn<-dbConnect(odbc::odbc(), .connection_string = connectionString)
dbReadTable(conn, "Person")
于 2019-04-16T12:05:57.233 回答