MySQL中文乱码问题

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: MySQL中文乱码问题

游戏应用起来后,发现保存在数据库的中文记录都为乱码

可以直接这样看:

mysql -h127.0.0.1 -u root -p123456 --default-character-set=utf8

改动/etc/my.cnf

加default-character-set=utf8

如果是5.1版本后,需要改成

character-set-server=utf8

否则会报:Starting MySQL...The server quit without updating PID file [失败]lib/mysql/localhost.localdomain.pid).异常

其他属性可加为:

skip-character-set-client-handshake

init-connect='SET NAMES utf8'

重启mysql

-----------------------------参考文章

mysql5.1以上版本中文乱码的解决方法

这几天新配了一台centos5.5服务器(64位),安装了mysql5.5版本,安装后发现存入数据库后的中文为乱码,按照以前的方式(mysql5.1以前的版本),从/usr/share/mysql目录,复制一个my-xxx.cnf到/etc/my.cnf,并将/etc/my.cnf内的mysqld段,添加上default_character_set=utf8上后,就能解决这个问题了。不过,在mysql5.5上却不行了。此时,重启mysql,问题就来了。一直会报Starting MySQL...The server quit without updating PID file [失败]lib/mysql/localhost.localdomain.pid).异常。但是只要一去掉default_character_set=utf8这句后,就又能重新正常启动。好吧,我们打开启动日志,看下到底发生了什么事情了。

      在my.cnf内添加以下代码输出err日志信息:

[safe_mysqld]

err-log = /var/log/mysqld.log

pid-file = /var/lib/mysql/localhost.localdomain.pid

在shell中输入/bin/sh /usr/bin/mysqld_safe & 启动mysql,shell输出如下:

110328 11:39:55 mysqld_safe Logging to '/var/lib/mysql/localhost.localdomain.err'.

110328 11:39:55 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql

110328 11:39:57 mysqld_safe mysqld from pid file /var/lib/mysql/localhost.localdomain.pid ended

查看vi /var/lib/mysql/localhost.localdomain.err文件,终于发现了错误代码了,如下:

110328 11:26:57 [ERROR] /usr/sbin/mysqld: unknown variable 'default_character_set=utf8'

110328 11:26:57 [ERROR] Aborting

难怪一加上default_character_set选项后,就无法启动,原来mysql5.5将这个参数给去掉了。

google一把,查看官方文档后,发现在新版本中,需要使用character_set_server来代替default_character_set参数。详细可以参考:http://dev.mysql.com/doc/refman/5.5/en/server-options.html#option_mysqld_default-character-set,仔细看下这个页面,会发现原来从mysql5.1后就已经作了修改了。

因此,你要是使用mysql5.1以上版本有乱码问题,不妨试试以上的方法。

在处理解决问题的过程中,google时,发现也有不少我同样的问题的,但是大部分都是mysql5.1以前的版本解决方法。若是使用的mysql5.1以上的新版本的TX,希望以上方法能解决您的问题。Good Luck。


也可以在登录mysql的时候强制确定编码:

mysql -h 10.161.165.13 -u mgame --default-character-set=utf8 -p


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
7月前
|
关系型数据库 MySQL Java
windows下mybatis插入mysql数据中文乱码问题解决
windows下mybatis插入mysql数据中文乱码问题解决
272 0
|
7月前
|
关系型数据库 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 和中文乱码问题处理
85 0
|
关系型数据库 MySQL 数据库
mysql中文乱码解决方法
mysql中文乱码解决方法
370 0
mysql中文乱码解决方法
|
关系型数据库 MySQL Java
Mysql中文乱码问题-设置MySQL编码-windows
在实际开发中经常遇到JDBC连接数据库,存入或获取数据乱码的问题,主要原因是MySQL安装的时候的编码设置为设置为UTF-8,这里给出详细解决方案
|
关系型数据库 MySQL Java
eclipse写入mysql中文乱码
eclipse写入mysql中文乱码
186 0
|
存储 关系型数据库 MySQL
MySQL中文乱码问题探究
MySQL中文乱码问题探究
178 0
MySQL中文乱码问题探究
|
关系型数据库 MySQL
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
450 0
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
|
SQL 关系型数据库 MySQL
MySQL - Linux下MySQL中文乱码(中文问号)解决办法
MySQL - Linux下MySQL中文乱码(中文问号)解决办法
983 0
|
SQL 关系型数据库 MySQL
深入浅出MySQL(五) MySQL5.5的中文乱码坑
深入浅出MySQL(五) MySQL5.5的中文乱码坑
269 0
|
关系型数据库 MySQL 数据库
mysql中文乱码
mysql是我们项目中非常常用的数据型数据库。但是因为我们需要在数据库保存中文字符,所以经常遇到数据库乱码情况。下面就来介绍一下如何彻底解决数据库中文乱码情况。 1、中文乱码 1.1、中文乱码 create table user(name varchar(11)); # 创建user表 i...
2799 0