mysql5.1 中文乱码_解决 Sequelize + MySQL5.1 读写中文乱码

一、背景

使用 Sequelize(6.3.4) 进行 MySQL5.1 数据操作,在本地运行没问题,但是推上服务器之后,读写数据都出现了中文乱码的问题。

二、解决过程

第一反应是连接数据库时没设置 UTF8 字符集导致的,于是先设置了字符集。

const sqlIns = new Sequelize(mysqlConf.$mysql_database, mysqlConf.$mysql_username, mysqlConf.$mysql_password, {

host: mysqlConf.$mysql_server_name,

dialect: 'mysql',

timezone: '+08:00',

define: {

charset: 'utf8',

dialectOptions: {

collate: 'utf8_general_ci'

}

}

});

重启 Node 服务 pm2 restart all,无果。

继续查询了数据库的字符编码:

# sql

show variables like '%char%';

# result

character_set_client utf8

character_set_connection utf8

character_set_database utf8

character_set_filesystem binary

character_set_results utf8

character_set_server latin1

character_set_system utf8

character_sets_dir /usr/share/mysql/charsets/

修改 Linux MySQL 配置文件 /etc/my.cnf:

# shell

vim /etc/my.cnf

# /etc/my.cnf

[mysqld]

character-set-server=utf8

[client]

default-character-set=utf8

[mysql]

default-character-set=utf8

重启 MySQL 服务 service mysqld restart,无果。

经过一系列搜索后,尝试了一个 ISSUE: Need "SET NAMES utf8" #395 中的解决办法,修改下 Sequelize 配置字符集的层级。

const sqlIns = new Sequelize(mysqlConf.$mysql_database, mysqlConf.$mysql_username, mysqlConf.$mysql_password, {

host: mysqlConf.$mysql_server_name,

dialect: 'mysql',

timezone: '+08:00',

dialectOptions: {

charset: 'utf8'

}

});

重启 Node 服务 pm2 restart all,成功读写中文字符!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值