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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 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;

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
关系型数据库 MySQL Java
windows下mybatis插入mysql数据中文乱码问题解决
windows下mybatis插入mysql数据中文乱码问题解决
490 0
|
关系型数据库 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 和中文乱码问题处理
187 0
|
关系型数据库 MySQL Shell
MySQL中文乱码问题
MySQL中文乱码问题
122 0
|
关系型数据库 MySQL 数据库
mysql中文乱码解决方法
mysql中文乱码解决方法
511 0
mysql中文乱码解决方法
|
存储 缓存 关系型数据库
【大数据系列之MySQL】(一):安装MySQL5.5版本数据库
【大数据系列之MySQL】(一):安装MySQL5.5版本数据库
262 0
【大数据系列之MySQL】(一):安装MySQL5.5版本数据库
|
关系型数据库 MySQL Java
Mysql中文乱码问题-设置MySQL编码-windows
在实际开发中经常遇到JDBC连接数据库,存入或获取数据乱码的问题,主要原因是MySQL安装的时候的编码设置为设置为UTF-8,这里给出详细解决方案
|
存储 关系型数据库 MySQL
MySQL中文乱码问题探究
MySQL中文乱码问题探究
219 0
MySQL中文乱码问题探究
|
关系型数据库 MySQL
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
556 0
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
|
SQL 关系型数据库 MySQL
MySQL5.7及以上 转 MySQL5.5
MySQL5.7及以上 转 MySQL5.5
312 0
|
关系型数据库 MySQL Java
eclipse写入mysql中文乱码
eclipse写入mysql中文乱码
320 0

推荐镜像

更多
下一篇
oss云网关配置