如何让R语言通过ODBC连接SQLSERVER数据库

浏览: 2081

一、 安装RODBC库

1、进入R语言的GUI界面(RGUI.EXE),在菜单栏选择“程序包/安装程序包”(如图)

Clipboard Image.png

2、在弹出的窗口里往下拉,选择RODBC如图,点击确定

Clipboard Image.png

3、在ODBC数据源管理器里将需要的数据库添加进去,这里笔者使用的是SQL Server2008,驱动程序选择Native Client10.0

Clipboard Image.png

3、在R语言窗口输入连接语句

> library(RODBC)
**这里是载入RODBC库
> channel<-odbcConnect(“MyTest”,uid=”ripley”,case=”tolower”)
**连接刚才添加进数据源的“MyTest”数据库
**ch <- odbcConnect(“some dsn “, uid = “user “, pwd = “**** “)
**表示用户名为user,密码是****,如果没有设置,可以直接忽略> data(USArrests)
**将“USArrests”表写进数据库里(这个表是R自带的)
> sqlSave(channel,USArrests,rownames = “state”,addPK = TRUE)
**将数据流保存,这时候打开SQL Server就可以看到新建的USArrests表了
> rm(USArrests)
> sqlTables(channel)
**给出数据库中的表
> sqlFetch(channel,”USArrests”,rownames = “state”)
**输出USArrests表中的内容
> sqlQuery(channel,”select * from USArrests”)

**调用SELECT查询语句并返回结果(如图)

Clipboard Image.png


> sqlDrop(channel,”USArrests”)
**删除表
> odbcClose(channel)
**最后要记得关闭连接
当然,通过这个办法也可以读取Excel、Access表中的内容,具体方法类似,这里不再重复
推荐 3
本文由 若玲 创作,采用 知识共享署名-相同方式共享 3.0 中国大陆许可协议 进行许可。
转载、引用前需联系作者,并署名作者且注明文章出处。
本站文章版权归原作者及原出处所有 。内容为作者个人观点, 并不代表本站赞同其观点和对其真实性负责。本站是一个个人学习交流的平台,并不用于任何商业目的,如果有任何问题,请及时联系我们,我们将根据著作权人的要求,立即更正或者删除有关内容。本站拥有对此声明的最终解释权。

3 个评论

学长,sqlQuery里面的channel指数据库里面的表还是设么,用了表名没用
非常赞~
没有看到有RODBC的选项

要回复文章请先登录注册