【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

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG