什么是R语言?
????? R语言是开源的统计分析工具,目前有着良好的应用前景,在许多领域与专业的分析工具相比有过之而无比及,但是要求使用的人员具备一定的编程基础,因此门槛相对较高一些,详细的介绍可以浏览R语言的国内官网(http://www.rproject.cn)?
那么如何让R语言能够读写SQL Server里的数据呢?
一、?安装RODBC库
1、进入R语言的GUI界面(RGUI.EXE),在菜单栏选择“程序包/安装程序包”(如图)
?
2、在弹出的窗口里往下拉,选择RODBC如图,点击确定
?
3、在ODBC数据源管理器里将需要的数据库添加进去,这里笔者使用的是SQL Server2008,驱动程序选择Native Client10.0 > library(RODBC) **这里是载入RODBC库 **连接刚才添加进数据源的“MyTest”数据库 **ch <- odbcConnect("some dsn ", uid = "user ", pwd = "**** ") **表示用户名为user,密码是****,如果没有设置,可以直接忽略 **将“USArrests”表写进数据库里(这个表是R自带的) **将数据流保存,这时候打开SQL Server就可以看到新建的USArrests表了 **给出数据库中的表 **输出USArrests表中的内容 **调用SELECT查询语句并返回结果(如图) > sqlDrop(channel,"USArrests") **删除表 > odbcClose(channel) **最后要记得关闭连接 ? 当然,通过这个办法也可以读取Excel、Access表中的内容,具体方法类似,这里不再重复 ? 感谢大家的阅读,有任何疑问或者想交流的都可以发邮件([email protected])给我哦!
?
?3、在R语言窗口输入连接语句
> channel<-odbcConnect("MyTest",uid="ripley",case="tolower")
> data(USArrests)
> sqlSave(channel,USArrests,rownames = "state",addPK = TRUE)
> rm(USArrests)
> sqlTables(channel)
> sqlFetch(channel,"USArrests",rownames = "state")
> sqlQuery(channel,"select * from USArrests")
??
?