将MS Access数据库连接到R

时间:2017-08-22 11:12:30

标签: r ms-access odbc r-dbi nanodbc

我想用MSI包将MS Access数据库连接到R. 我试试这个:

library(DBI) con <- dbConnect(odbc::odbc(), "BASE_MEPSA")

我有这个错误

  

错误:nanodbc / nanodbc.cpp:950:HY024:[Microsoft] [Pilote ODBC Microsoft Access]«(Inconnu)»

但是使用RODBC我没有问题

library(RODBC) base1<-odbcDriverConnect("Driver={Microsoft Access Driver (*.mdb, *.accdb)};DBQ=C:/Users/IPS/Desktop/divers/dt/stateduc_R/BASE_MEPSA.mdb")

如何使用DBI包将MS Access连接到R?

2 个答案:

答案 0 :(得分:1)

&#34; BASE_MEPSA&#34;数据源名称(DSN)的名称?您可以在ODBC数据源管理器中创建它。如果是这样,我总能成功连接:

library(DBI) 
cn <- dbConnect(odbc::odbc(), dsn="BASE_MEPSA")

此外,您需要确保使用相同的体系结构。这意味着如果您的Access版本是x32,您应该使用R32,Access和ODBC数据源管理的x32版本。您必须在R的全局设置中更改此值,因为默认值为x64。

还尝试使用您用于RODBC的文件路径。

cn <- dbConnect(odbc::odbc(), DBQ="C:/Users/IPS/Desktop/divers/dt/stateduc_R/BASE_MEPSA.mdb")

答案 1 :(得分:1)

library(RODBC) 
mdbConnect<-odbcConnectAccess("D:/SampleDB1/sampleDB1.mdb")


# Load RODBC package
library(RODBC)

# Connect to Access db
# for 32-bit windows
channel <- odbcConnectAccess("C:/your_path/Database1.accdb")

# Get data
data <- sqlQuery(channel , paste ("select * from Table1"))



#load package
library("RODBC") 

# for 64-bit windows
#connect database.
db<-file.path("C:/Users/Excel/Desktop/Coding/Microsoft Access/Split_and_Transpose.accdb") 

#internal RODBC function
channel<-odbcConnectAccess2007(db) 

#read particular table from Access database file.
dataSetName<-sqlFetch(channel,"Table1") 

#do not forget this, otherwise you lock access database from editing.
close(channel) 

这是一个很好的资源。

https://cran.r-project.org/web/packages/RODBC/vignettes/RODBC.pdf