我想用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?
答案 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