
首先要下载加载RMySQL这个包。
加载的时候可以使用
[plain] view plain copy
require(RMySQL)
或者
[plain] view plain copy
library(RMySQL)
这两个语句的功能是一样的。
现在是建立连接:
[plain] view plain copy
con<-dbConnect(MySQL(),host='localhost',port=3306,dbname="XXX",user="root",password="XXXXX")
这里连接的是本地数据库,host=‘localhost’,也可以写成host='127.0.0.1',port为端口,如果不知道的话可以在mysql控制台输入 status来查看数据库的当前配置。其中就包括端口。user为用户名,一般为root,password是你的数据库的密码。
若数据库中的信息是中文,我们就要修改此连接的编码,否则就会出现乱码。
[plain] view plain copy
dbSendQuery(con,"set character_set_result=gbk")
dbSendQuery(con,"set character_set_connection=gbk")
dbSendQuery(con,"set character_set_database=gbk")
dbSendQuery(con,"set character_set_client=gbk")
这样就搞定了,R已经连接到我们自己的MySQL数据库了。
一、配置数据源1
下载Connector/ODBC
该软件相当于R与Mysql的桥梁,下载地址请看图片;
R连接数据库(MySql)
2
安装Connector/ODBC
下载后,双击安装文件,默认选项安装,只管点击下一步直至“finish",成功安装后将在C:\Program Files\MySQL\中看到如下文件(Connector ODBC 5.3);
R连接数据库(MySql)
3
配置数据源
打开”控制面板——>管理工具“,找到”数据源(ODBC)“并双击;
R连接数据库(MySql)
4
添加ODBC Driver
单击右侧”添加“按钮,选中ODBC Driver,在d出的对话框中依次填写各项信息:
data source name:随意填,如mysql_data
description:随意填,如mydata
TCP/IP Server:填写服务器IP,通常为”127.0.0.1“
user:填写你的mysql用户名
password:填写你的mysql密码
最后在数据库中选中你将要 *** 纵的数据库,单击完成。
R连接数据库(MySql)
R连接数据库(MySql)
END
二、连接数据库
1
R中创建数据框
打开R软件,将你需要保存到数据库的数据传入数据框。如从桌面导入.csv数据到数据框myframe
file <- "C:/Users/Administrator/Desktop/TEST.csv"
myframe <- read.table(file, header = TRUE, sep = ",")
myframe[1:10,] #查看你传入数据框中的数据
R连接数据库(MySql)
2
通过R创建数据库表
此处将上面myframe数据框中的数据存入数据库中,并将表名命名为”population“;
install.packages("RODBC") #如果你还没有安装此包
library(RODBC)
channel <- odbcConnect("mysql_data", uid = "root", pwd = "******")
sqlSave(channel, myframe, tablename = "population", append = FALSE)
close(channel)
R连接数据库(MySql)
3
校验结果
打开你的数据库,在数据库中查看刚才用R创建的数据库表是否存在。该例用R创建的数据库表名为”population“,打开数据库,发现”population“表已经成功创建到数据库。心痒痒吧,还等神马,赶紧动手试试!!!
R连接数据库(MySql)
R连接数据库(MySql)
END
后记
R与数据库(Mysql)间的桥梁已经搭好,并在案例中演示了向数据库存入数据的过程,相信你早已的脑洞大开,接下来从数据库中删出某个表、取数据等就不是问题了。
R连接数据库(MySql)
END
注意事项
细心的你已经发现,在配置数据源的第四个步骤中设置的data source name值”mysql_data",正是R中创建数据库连接odbcConnect函数的第一个参数值。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)