【R语言 连接数据库 】RMySQL数据库编程指南

2024-09-07 06:48

本文主要是介绍【R语言 连接数据库 】RMySQL数据库编程指南,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里写图片描述

主要内容

1、RMySQL介绍
2、RMySQL安装方法
3、R连接本地mysql
4、R连接远程mysql
5、R查询mysql数据
6、R插入数据到mysql
7、R调用mysql中的存储过程

1. RMySQL介绍

MySQL是一款最常用到开源数据库软件,安装简单,运行稳定,非常适用于中小型的数据存储。R作为数据分析的工具,当然要支持数据库驱动接口。让R和MySQL配合在一起,所能爆发出的能量是巨大的。

RMySQL一个R语言程序包,提供了访问MySQL数据库的R语言接口程序,RMySQL需求依赖于DBI项目。RMySQL不仅提供了基本的数据库访问,SQL查询,还封装了一些方法。比较读整表,分页,data.frame快速插入等等的功能。掌握好RMySQL,数据库编辑将得心应手!!

2、RMySQL安装

install.packages('RMySQL')

3、通过R程序,读MySQL数据库数据。

对于大数据,我们自然不能用Excel之流存放,通常我们将它们存在数据库中,一个比较优秀的数据库软件就是MySQL,可以让我们读取查询数据库中的相关内容。R中的RMySQL包提供了这么一个读取MySQL数据的办法,并可以使用SQL语句对数据进行查询。
一些有用的函数:

dbConnect:连接数据库dbDisconnect:取消数据库连接dbGetQuery:执行一条SQL语句,将查询结果写为一个数据框dbListTables:列出数据库中的表的名称dbListFields:获取列表的每一列的名称dbReadTable:读取数据库中的一张表dbSendQuery:执行一条SQL语句,返回一个数据库对象

3.1、连接本地mysql,读取数据

mysql建表语句

CREATE TABLE t_blog(
id INT PRIMARY KEY AUTO_INCREMENT,
title varchar(12) NOT NULL UNIQUE,
author varchar(12) NOT NULL, 
length int NOT NULL,
create_date timestamp NOT NULL DEFAULT now()
)ENGINE=INNODB DEFAULT CHARSET=UTF8;

mysql插入语句

INSERT INTO t_blog(title,author,length) values('你好,第一篇','Conan',20),('RMySQL数据库编程','Conan',99),('R的极客理想系列文章','Conan',15);

这里写图片描述

R语言 连接本地 mysql ,插入数据,查询数据


rm(list=ls())
gc()
library(RMySQL)########建立本地连接mysql
conn <- dbConnect(MySQL(), dbname = "cgjr", username="root", password="12345",client.flag=CLIENT_MULTI_STATEMENTS)# ###########设置gbk显示中文
# dbGetQuery(conn,'SET NAMES gbk')
# 
# query<-dbGetQuery(conn, "SELECT * FROM persons")# 建表并插入数据dbSendQuery(conn,'SET NAMES gbk')
dbSendQuery(conn,"INSERT INTO t_blog(title,author,length) values('R插入的新文章','Conan',50)");query<-dbSendQuery(conn, "SELECT * FROM t_blog")data <- fetch(query, n = -1)print(data)##########关闭连接
dbDisconnect(conn)
> print(data)id               title author length         create_date
1  1        你好,第一篇  Conan     20 2017-12-12 16:03:29
2  2    RMySQL数据库编程  Conan     99 2017-12-12 16:03:29
3  3 R的极客理想系列文章  Conan     15 2017-12-12 16:03:29
4  4       R插入的新文章  Conan     50 2017-12-12 16:05:20
> 

3.2、远程连接线上mysql 数据库

rm(list=ls())
gc()
library(RMySQL)conn <- dbConnect(MySQL(), dbname = "cgjr", username="ldf", password="XXXXXX",host="XXXXXX",port=XXXXX)dbSendQuery(conn,'SET NAMES gbk')query<-dbSendQuery(conn, "SELECT user_id,province,city,district from t_mobile_position WHERE CONCAT(province,city,district) REGEXP '赣州市南康区'  LIMIT 20")data <- fetch(query, n = -1)print(data)dbDisconnect(conn)
> print(data)user_id province   city district
1  191805022214   江西省 赣州市   南康区
2  191805022214   江西省 赣州市   南康区
3  191805022214   江西省 赣州市   南康区
4  191805022214   江西省 赣州市   南康区
5  191805022214   江西省 赣州市   南康区
6  191805835201   江西省 赣州市   南康区
7  191805835201   江西省 赣州市   南康区
8  191805835201   江西省 赣州市   南康区
9  191805835201   江西省 赣州市   南康区
10 191806098337   江西省 赣州市   南康区
11 191806098337   江西省 赣州市   南康区
12 191806098337   江西省 赣州市   南康区
13 191806098337   江西省 赣州市   南康区
14 191806098337   江西省 赣州市   南康区
15 191806098337   江西省 赣州市   南康区
16 191806191478   江西省 赣州市   南康区
17 191806191478   江西省 赣州市   南康区
18 191806191478   江西省 赣州市   南康区
19 191806191478   江西省 赣州市   南康区
20 191806385456   江西省 赣州市   南康区

3.3、 R语言调用mysql 存储过程

rm(list=ls())
gc()
library(RMySQL)
########建立本地连接mysql
conn <- dbConnect(MySQL(), dbname = "cgjr", username="root", password="12345",client.flag=CLIENT_MULTI_STATEMENTS)
dbSendQuery(conn,'SET NAMES gbk')
query<-dbSendQuery(conn, "call add_student(3)")##########关闭连接
dbDisconnect(conn)

这篇关于【R语言 连接数据库 】RMySQL数据库编程指南的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1144361

相关文章

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v