R 语言写入 RMySQL 中文乱码

R语言在windows 平台写入 MySQL 可以使用下面的库:

library(RMySQL)


con <- RMySQL::dbConnect(MySQL(),host='localhost', port=3306, user='username', password='passwd',dbname='testDB')

dbSendQuery(con,'SET NAMES gbk')  ==> 用于处理中文乱码问题,详情见下文

常用的命令:

dbListTables(con)

dbRemoveTable(con,"testtable")

fruits <-data.frame(id=1:5,name=c("苹果","香蕉","梨子","玉米","西瓜"),price=c(8.8,4.98,7.8,6,2.1),status=c("无","打折","无","售罄","批发"))

dbWriteTable(con,"fruits",fruits,append=TRUE)

dbReadTable(con,"fruits")
res=dbSendQuery(con,"select * from fruits order by price") 
dat=fetch(res)


由于MySQL 默认不支持中文,需要在 MySQL 里面增加对中文的支持

在Linux 平台,做如下修改:

sudo vim ./mysql.conf.d/mysqld.cnf

[mysqld_safe]
socket          = /var/run/mysqld/mysqld.sock
nice            = 0
# For Chinese characters
character-set-server=gbk

[mysqld]
#
# * Basic Settings
#
user            = mysql
# For Chinese characters
character-set-server=gbk
修改完成之后,重启 mysql 服务

sudo /etc/init.d/mysql restart


登入 mysql:

mysql -u root -p
xxxxxx
mysql> show variables like "char%";
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | gbk                        |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | gbk                        |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)

把原来的数据库删掉,重新创建数据库和表,就可以解决中文问题


> dbReadTable(con,"fruits")
   row_names id name price status
1          1  1 苹果  8.80     无
2          2  2 香蕉  4.98   打折
3          3  3 梨子  7.80     无
4          4  4 玉米  6.00   售罄
5          5  5 西瓜  2.10   批发



评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值