01. Mac上安装MySQL
访问MySQL的官网http://www.mysql.com/downloads/ 然后在页面中会看到“MySQL Community Server”下方有一个“download”点击。进入MySQL的下载界面(http://www.mysql.com/downloads/mysql/),如果你是用的Mac OS来访问的话那么就会默认为你选好了Mac OS X 平台,而下面罗列的都是在Mac OS上能用的MySQL的版本,如果是用的其他平台,在“Select Platform”选项的下拉列表中选一下就好了。按照安装步骤一路向下走,记得保存最后弹出框中的密码(它是你mysql root账号的密码)。 打开设置并且点击MySQL并开启MySQL服务。
此时我们在终端输入此时我们在命令行输入mysql -uroot -p命令会提示没有commod not found,我们还需要将mysql加入系统环境变量。
(1).进入/usr/local/mysql/bin,查看此目录下是否有mysql。
(2).执行vim ~/.bash_profile
PATH=$PATH:/usr/local/mysql/bin
添加完成后,按esc,然后输入wq保存。最后在命令行输入source ~/.bash_profile。
现在你就可以通过mysql -uroot -p登录mysql了,会让你输入密码,就是之前弹窗中记录的密码
至此MySQL成功安装到mac电脑下,可以进行下面的开发了。
02. 安装RMySQL
安装RMySQL非常简单,安装之后可以使用help命令查询包的介绍信息
install.packages("RMySQL")
library(RMySQL)
help("RMySQL")
03. RMySQL基本操作
创造一个新的数据库并使用,SQL查询可以通过dbSendQuery或dbGetQuery传给数据库管理系统。dbGetQuery传送查询语句,把结果以数据框形式返回。dbSendQuery传送查询,返回的结果是继承"DBIResult"的一个子类的对象。函数fetch用于获得查询结果的部分或全部行,并以列表返回。函数dbHasCompleted确定是否所有行已经获得了,而dbGetRowCount返回结果中行的数目。如果只是简单的读整个表,也可以用dbReadTable函数。
library(RMySQL)
mydb = dbConnect(MySQL(), #数据库平台类型
user='root', #登录账号(MySQL初始安装时设置的账号)
password='password', #登录密码(MySQL初始安装时设置的密码)
host='localhost')
# creating a database using RMySQL in R
dbSendQuery(mydb, "CREATE DATABASE bookstore;")
dbSendQuery(mydb, "USE bookstore;")
# reconnecting to database we just created using following command in R :
mydb = dbConnect(MySQL(), user='root', password='password', host='localhost', dbname="bookstore") # 重连数据库
dbSendQuery(mydb, "drop table if exists books, authors")
在数据库中创造表:
# creating tables in bookstore:
dbSendQuery(mydb, "
CREATE TABLE books (
book_id INT,
title VARCHAR(50),
author VARCHAR(50));")
显示数据库中的表:
# Show table using R:
dbListTables(mydb)
在包中插入新的列:
dbSendQuery(mydb, "ALTER TABLE books
CHANGE COLUMN book_id book_id INT AUTO_INCREMENT PRIMARY KEY,
CHANGE COLUMN author author_id INT,
ADD COLUMN description TEXT,
ADD COLUMN genre ENUM('novel','poetry','drama', 'tutorials', 'text', 'other'),
ADD COLUMN publisher_id INT,
ADD COLUMN pub_year VARCHAR(4),
ADD COLUMN isbn VARCHAR(20);")
创造新的表并创造一些列名:
# Now, Before moving on to adding data to our books table, let's quickly set up the authors table.
dbSendQuery(mydb, "CREATE TABLE authors
(author_id INT AUTO_INCREMENT PRIMARY KEY,
author_last VARCHAR(50),
author_first VARCHAR(50),
country VARCHAR(50));")
往新的表中插入数据:
# Adding data into tables
dbSendQuery(mydb, "INSERT INTO authors
(author_last, author_first, country)
VALUES('Kumar','Manoj','India');")
从数据库中获取选取结果:
# fetching last data insert id number:
last_id = fetch(dbSendQuery(mydb, "SELECT LAST_INSERT_ID();"))
last_id
插入新的值到book表,并查看插入的值:
# Inserting data into books table and using last insert ID number:
dbSendQuery(mydb, "INSERT INTO books
(title, author_id, isbn, genre, pub_year)
VALUES('R and MySQL', 1,'6900690075','tutorials','2014');")
try1 = fetch(dbSendQuery(mydb, "SELECT book_id, title, description FROM books WHERE genre = 'tutorials';"))
显示所有的表并插入数值到新的表:
dbListTables(mydb) # 显示所有的表
dbWriteTable(mydb, name = "mtcars", value = mtcars[,]) # 插入R自带的数据mtcars形成新的表
dbListTables(mydb)
插入表格的时候如果有错误的话如:
Error in .local(conn, statement, ...) : could not run statement: The used command is not allowed with this MySQL version
则是因为MySQL的一些安全问题,可以在MySQL的命令界面通过命令查询:
SHOW VARIABLES LIKE 'local_infile';
全局更改则可以依据以下命令:
SET GLOBAL local_infile = 1;
读取数据库里面的表格:
mtcars
head(mtcars)
删除表格:
dbGetQuery(mydb,"DROP TABLE mtcars")
dbListTables(mydb)
删除数据库:
dbGetQuery(mydb,"DROP DATABASE bookstore;")
断开连接:
dbDisconnect(mydb)
04. 相关
查询mysql数据存放的位置
mysql> show global variables like "%datadir%";
Mac系统下默认是没有MySQL的配置文件my.cnf的,如果需求的话需要自己创建并修改。