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


相关实践学习
每个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数据中文乱码问题解决
455 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 和中文乱码问题处理
155 0
|
关系型数据库 MySQL 数据库
mysql中文乱码解决方法
mysql中文乱码解决方法
480 0
mysql中文乱码解决方法
|
关系型数据库 MySQL Java
Mysql中文乱码问题-设置MySQL编码-windows
在实际开发中经常遇到JDBC连接数据库,存入或获取数据乱码的问题,主要原因是MySQL安装的时候的编码设置为设置为UTF-8,这里给出详细解决方案
|
关系型数据库 MySQL Java
eclipse写入mysql中文乱码
eclipse写入mysql中文乱码
309 0
|
存储 关系型数据库 MySQL
MySQL中文乱码问题探究
MySQL中文乱码问题探究
208 0
MySQL中文乱码问题探究
|
关系型数据库 MySQL
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
533 0
解决Navicat中文乱码问题(mac版本,MySQL显示正常)
|
SQL 关系型数据库 MySQL
MySQL - Linux下MySQL中文乱码(中文问号)解决办法
MySQL - Linux下MySQL中文乱码(中文问号)解决办法
1178 0
|
SQL 关系型数据库 MySQL
深入浅出MySQL(五) MySQL5.5的中文乱码坑
深入浅出MySQL(五) MySQL5.5的中文乱码坑
336 0
|
关系型数据库 MySQL 数据库
mysql中文乱码
mysql是我们项目中非常常用的数据型数据库。但是因为我们需要在数据库保存中文字符,所以经常遇到数据库乱码情况。下面就来介绍一下如何彻底解决数据库中文乱码情况。 1、中文乱码 1.1、中文乱码 create table user(name varchar(11)); # 创建user表 i...
2898 0

推荐镜像

更多