【转】r 读取mysql 中文乱码_R读取MySQL数据出现乱码
2022/5/25 2:21:46
本文主要是介绍【转】r 读取mysql 中文乱码_R读取MySQL数据出现乱码,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
最终的解决办法直接看 4
我的思路:
我用的都是utf-8编码,电脑系统win7, MySQL-Front进行数据库的可视化。
1、我用的是RStudio,先去设置R的默认编码:
Tools→Global Options...→Code→Saving→如下
虽然设置了R的默认编码,但是问题仍然存在。
2、用dbSendQuery(con, "SET NAMES utf8"), 依旧是乱码
library("RMySQL");
con
dbSendQuery(con, "SET NAMES utf8"); #说明用什么字符集来获取数据库字段
query
result
3、既然是从MySQL中读取数据,那就看看是不是MySQL中的编码设置不统一。
方法一 : 参考MySQL字符集专题(字符集,校对,乱码) 该文章的2.3 2.4 4.2
#查看当前数据库字符集
show variableslike 'character%';
#查看当前数据库字符集校对
show variableslike 'collation%';
我的结果:
可以看到其中的很多编码都是不统一的,用如下方法设置:
或者是方法二
通过MySQL命令行修改:(编码可选)
mysql> set character_set_client=utf8;
mysql> set character_set_connection=utf8;
mysql> set character_set_database=utf8;
mysql> set character_set_results=utf8;
mysql> set character_set_server=utf8;
mysql> set character_set_system=utf8;
mysql> set collation_connection=utf8;
mysql> set collation_database=utf8;
mysql> set collation_server=utf8;
设置后我的MySQL-Front编辑器中输出的结果仍然未变,我就用了,如下的方法三,成功把编码都改为utf8。
方法三: 在MySQL-Front编辑器输入如下,进行运行。
set character_set_client='utf8';set character_set_connection='utf8';set character_set_results='utf8';set character_set_server='utf8';
set collation_connection='utf8_unicode_ci';
set collation_server='utf8_unicode_ci';
4、经过3将MySQL中的编码设置一致,但是问题依然没有解决,无意间将 dbSendQuery(con, "SET NAMES gbk") 设为gbk,乱码问题解决。
library("RMySQL");
con
dbSendQuery(con, "SET NAMES gbk"); #说明用什么字符集来获取数据库字段
query
result
R的字符编码使用的gbk,所以读取时的数据需要设定为gbk,数据库 ,工作环境,本地 需要保持一致。
这篇关于【转】r 读取mysql 中文乱码_R读取MySQL数据出现乱码的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-23BinLog入门:新手必读的MySQL二进制日志指南
- 2024-10-23Binlog入门:MySQL数据库的日志管理指南
- 2024-10-22MySQL数据库入门教程:从安装到基本操作
- 2024-10-22MySQL读写分离入门教程:轻松实现数据库性能提升
- 2024-10-22MySQL分库分表入门教程
- 2024-10-22MySQL慢查询的诊断与优化指南
- 2024-10-22MySQL索引入门教程:快速理解与应用指南
- 2024-10-22MySQL基础入门教程:从安装到基本操作
- 2024-10-22MySQL数据库中的Binlog详解与操作教程
- 2024-10-12部署MySQL集群项目实战:新手入门教程