深入浅出MySQL(五) MySQL5.5的中文乱码坑

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 深入浅出MySQL(五) MySQL5.5的中文乱码坑

这一次的记录主要是针对mysql5.5版本里面的中文乱码而言,这里用到的操作系统是centos7,数据库是mysql5.5,云平台是阿里云


一、登录MySQL查看用SHOW VARIABLES LIKE ‘character%’;下字符集,显示如下:


+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
复制代码


二、修改mysql的my.cnf文件中的字符集键值(注意配置的字段细节):


1、在[client]字段里加入default-character-set=utf8,如下:


[client]
port = 3306
socket = /var/lib/mysql/mysql.sock
default-character-set=utf8
复制代码


2、在[mysqld]字段里加入character-set-server=utf8,如下:


[mysqld]
port = 3306
socket = /var/lib/mysql/mysql.sock
character-set-server=utf8
复制代码


3、在[mysql]字段里加入default-character-set=utf8,如下:


[mysql]
no-auto-rehash
default-character-set=utf8
复制代码


修改完成后,使用命令:service mysql restart重启mysql服务就生效。注意:[mysqld]字段与[mysql]字段是有区别的。


使用SHOW VARIABLES LIKE ‘character%’;查看,发现数据库编码全已改成utf8。


+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
复制代码


4、如果上面的都修改了还乱码,那剩下问题就一定在connection连接层上。解决方法是在发送查询前执行一下下面这句(直接写在SQL文件的最前面):


SET NAMES ‘utf8’;

它相当于下面的三句指令:

SET character_set_client = utf8;

SET character_set_results = utf8;

SET character_set_connection = utf8;

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6月前
|
关系型数据库 MySQL Java
windows下mybatis插入mysql数据中文乱码问题解决
windows下mybatis插入mysql数据中文乱码问题解决
227 0
|
6月前
|
关系型数据库 MySQL Linux
MySQL【部署 01】Linux root 用户部署 mysql-5.7.28 及 not allowed to connect to this MySQL server 和中文乱码问题处理
MySQL【部署 01】Linux root 用户部署 mysql-5.7.28 及 not allowed to connect to this MySQL server 和中文乱码问题处理
78 0
|
关系型数据库 MySQL Shell
MySQL中文乱码问题
MySQL中文乱码问题
52 0
|
关系型数据库 MySQL 数据库
mysql中文乱码解决方法
mysql中文乱码解决方法
331 0
mysql中文乱码解决方法
|
关系型数据库 MySQL Java
Mysql中文乱码问题-设置MySQL编码-windows
在实际开发中经常遇到JDBC连接数据库,存入或获取数据乱码的问题,主要原因是MySQL安装的时候的编码设置为设置为UTF-8,这里给出详细解决方案
|
存储 缓存 关系型数据库
【大数据系列之MySQL】(一):安装MySQL5.5版本数据库
【大数据系列之MySQL】(一):安装MySQL5.5版本数据库
128 0
【大数据系列之MySQL】(一):安装MySQL5.5版本数据库
|
SQL 关系型数据库 MySQL
MySQL5.7及以上 转 MySQL5.5
MySQL5.7及以上 转 MySQL5.5
160 0
|
关系型数据库 MySQL Java
eclipse写入mysql中文乱码
eclipse写入mysql中文乱码
182 0
|
存储 关系型数据库 MySQL
MySQL中文乱码问题探究
MySQL中文乱码问题探究
169 0
MySQL中文乱码问题探究
|
关系型数据库 MySQL
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
440 0
解决Navicat中文乱码问题(mac版本,MySQL显示正常)