您的当前位置:首页解决 mysql 中文乱码

解决 mysql 中文乱码

2023-11-12 来源:哗拓教育

mysql版本:5.6.38

 

虽然创建实例时选择的是utf-8的utf8_general_ci,但是用其他程序保存中文时依旧出现乱码的情况。

 

记录一种可行的解决方案,即修改数据库的字符集。

  

由于该环境的mysql我是使用yum的方式进行安装,所以mysql的配置文件路径:/etc/my.cnf

vim /etc/my.cnf

 

编辑内容,在[mysqld]下添加下面的内容,wq保存。

character_set_server = utf8

 

解决 mysql 中文乱码

标签:mysql   rac   记录   vim   char   其他   mysq   div   gen   

小编还为您整理了以下内容,可能对您也有帮助:

MySQL数据库中的中文乱码如何解决

mysql数据乱码问题可能有以下三种原因:

1.server本身设定问题,例如还停留在latin1版本;

2.table的语系设定问题(包含character与collation);

3.客户端程式(例如php,java)的连线语系设定问题;

建议使用utf8!!!!

想要避免mysql的中文乱码问题,可以尝试以下方法:

1,对于版本问题,建议去官网更新最新的版本或者比较好用的版本;

2,创建数据库,创建表时没有对字符编码进行设定会造成乱码问题:

创建数据库的时候:CREATE DATABASE `test`

CHARACTER SET 'utf8'

COLLATE 'utf8_general_ci';

建表的时候 CREATE TABLE `database_user` (

`ID` varchar(40) NOT NULL default '',

`UserID` varchar(40) NOT NULL default '',

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

3,对于第三种情况,参考一下方法:

编辑linux服务器中/etc/my.cnf文件,在[mysql]段加入default_character_set=utf8;

如果只是调试遇到乱码问题:

在编写Connection URL时,加上?useUnicode=true&characterEncoding=utf-8参数;

并且在网页代码中加上一个"set names utf8"或者"set names gbk"的指令,告诉MySQL连线内容都要使用utf-8或者gbk。

utf8或者gbk;

mysql出现乱码问题如何解决?

1、修改安装文件根目录下的my.ini文件:
搜索字段default-character-set,设置其值为utf8/gbk之一(注意设置utf8的时候不能设成utf-8)
再去重启MySQL服务器
如果还是出现乱码,接着执行下面操作
2、修改数据库编码
在安装目录的data目录下找到你出现乱码的数据库对应的文件夹(这个文件夹即是你这个数据库存放数据的地方),
进入找到db.opt文件(即此数据库的编码配置文件),修改值为下面的
default-character-set=gbk
default-collation=gbk_chinese_ci
再去重启MySQL服务器
如果还是出现乱码,接着执行下面操作
3、再不行,备份原数据库数据,直接drop掉这个数据库
重新创建数据库并设置编码
create database yourDB character set gbk;
别忘了重启MySQL服务器综上:如果还没有解决,我也没辙了。重装吧,重装的时候设置下编码三处的编码要一致

mysql出现乱码问题如何解决?

1、修改安装文件根目录下的my.ini文件:
搜索字段default-character-set,设置其值为utf8/gbk之一(注意设置utf8的时候不能设成utf-8)
再去重启MySQL服务器
如果还是出现乱码,接着执行下面操作
2、修改数据库编码
在安装目录的data目录下找到你出现乱码的数据库对应的文件夹(这个文件夹即是你这个数据库存放数据的地方),
进入找到db.opt文件(即此数据库的编码配置文件),修改值为下面的
default-character-set=gbk
default-collation=gbk_chinese_ci
再去重启MySQL服务器
如果还是出现乱码,接着执行下面操作
3、再不行,备份原数据库数据,直接drop掉这个数据库
重新创建数据库并设置编码
create database yourDB character set gbk;
别忘了重启MySQL服务器综上:如果还没有解决,我也没辙了。重装吧,重装的时候设置下编码三处的编码要一致

怎样解决MySQL中文显示乱码

推荐:《mysql视频教程》

java网站MySQL数据库个别文字乱码问题

乱码问题很让人头疼,特别是极其少量的乱码。这里分享一个个人开发过程中遇到的一个乱码问题,希望能对大家有所帮助。

方法/步骤

检查乱码出现位置——前台。

这里小编通过火狐浏览器的firebug工具检查了前台jsp页面,发现post的的确是utf8的数据。所以,排除前台传送数据时产生乱码。

检查乱码出现的位置——后台。

因为同事用来接收前台数据的是struts formbean的方式,所以小编不是很了解,就用了个笨办法:找到产生乱码的数据传递过程,对于过程中经过的每个方法都添加一个输出,在后台查看输出的数据。

结果,这些数据也是正常的。

检查乱码出现位置——MySQL数据库。

当排除了前后台,那么只剩下数据库了。那么问题就在数据库上了。

小编先在数据库里直接数据了乱码的汉字,发现可以存储。排除了数据库表的文字编码问题。

之后小编在工具软件中查询了一下(语句:show variables like '%char%';),结果如下图。问题一下子发现了:由于gb2312中汉字并不全,所以一些汉字是没有编码的,此时这些汉字就会被强制转换为“?”,至此这个汉字的数据就丢失了,而且不可还原。

3465428b844bd1d9c6295219814d360.png

原因详解:

MySQL数据库的数据进出实际上是有几道转换手续的。

其中进入的时候:character_set_client转character_set_connection转character_set_server存入数据库。

而取出的时候:数据库取出转character_set_server转character_set_result。

这样大家应该明白了吧,进出数据库的数据都要经过character_set_server转换,所以无论是前台的正确的汉字还是数据库内正确的汉字,只要不在gb2312内就会被转换成问号。

解决方法:

一劳永逸的方法,小编直接在serverMySQL文件夹内,将my.ini文件修改了。

修改过程为:找到[mysqld]再向下找几行发现“default_character_set=utf8”,在该行下添加一行“character_set_server=gbk”。

当然不是必须用gbk,小编是为了小心起见用了国标扩展,即gb2312的扩展gbk。

怎样解决MySQL中文显示乱码

推荐:《mysql视频教程》

java网站MySQL数据库个别文字乱码问题

乱码问题很让人头疼,特别是极其少量的乱码。这里分享一个个人开发过程中遇到的一个乱码问题,希望能对大家有所帮助。

方法/步骤

检查乱码出现位置——前台。

这里小编通过火狐浏览器的firebug工具检查了前台jsp页面,发现post的的确是utf8的数据。所以,排除前台传送数据时产生乱码。

检查乱码出现的位置——后台。

因为同事用来接收前台数据的是struts formbean的方式,所以小编不是很了解,就用了个笨办法:找到产生乱码的数据传递过程,对于过程中经过的每个方法都添加一个输出,在后台查看输出的数据。

结果,这些数据也是正常的。

检查乱码出现位置——MySQL数据库。

当排除了前后台,那么只剩下数据库了。那么问题就在数据库上了。

小编先在数据库里直接数据了乱码的汉字,发现可以存储。排除了数据库表的文字编码问题。

之后小编在工具软件中查询了一下(语句:show variables like '%char%';),结果如下图。问题一下子发现了:由于gb2312中汉字并不全,所以一些汉字是没有编码的,此时这些汉字就会被强制转换为“?”,至此这个汉字的数据就丢失了,而且不可还原。

3465428b844bd1d9c6295219814d360.png

原因详解:

MySQL数据库的数据进出实际上是有几道转换手续的。

其中进入的时候:character_set_client转character_set_connection转character_set_server存入数据库。

而取出的时候:数据库取出转character_set_server转character_set_result。

这样大家应该明白了吧,进出数据库的数据都要经过character_set_server转换,所以无论是前台的正确的汉字还是数据库内正确的汉字,只要不在gb2312内就会被转换成问号。

解决方法:

一劳永逸的方法,小编直接在serverMySQL文件夹内,将my.ini文件修改了。

修改过程为:找到[mysqld]再向下找几行发现“default_character_set=utf8”,在该行下添加一行“character_set_server=gbk”。

当然不是必须用gbk,小编是为了小心起见用了国标扩展,即gb2312的扩展gbk。

MySQL 中文字符乱码问题

推荐:《mysql视频教程》

mysql数据表中文乱码解决办法

在往 mysql 数据库中插入数据的时候出现数据 ( 汉字 ) 乱码情况:

在把数据库,数据表的编码改为UTF-8后,还是乱码。

edf6ec50db88676d679cf576b002996.png

Mysql的默认编码方式是Latin1,不支持中文,因此,如果要让mysql支持中文的话需要把数据库默认的编码修改为gbk或者utf8。

1.查看数据库的编码方式

mysql>show variables like 'character%';

d675682626fb9400a08c4959ca9db20.png

上面的各种字符设置必须一致,只是简单的对数据库、数据表设置编码格式不能完全解决乱码问题,我是将上面的说有字符编码全设置为utf8后解决的乱码问题。

对上面的信息加以说明:

 | character_set_client:客户端请求数据的字符集(编码方式) | character_set_connection:从客户端接收到数据,再传输的字符集(建立连接使用的编码) | character_set_database:默认数据库的字符集,无论默认数据库如何改变,都是这个字符集;如果没有默认数据库,那就使用 character_set_server 指定的字符集, 这个变量建议由系统自己管理,不要人为定义。 | character_set_results:结果集的字符集 | character_set_server:数据库服务器的默认字符集 | character_set_system:这个值总是utf8,不需要设置,是存储系统元数据的字符集

上述变量的值不一致或者显示乱码时,可以通过如下命令来修改:

mysql> SET character_set_client = utf8; mysql> SET character_set_results = utf8; mysql> SET character_set_connection = utf8;

2、找到MySQL5.0安装目录下编辑打开my.ini文件,修改为:

[client]port=3306default-character-set=utf8[mysql]default-character-set=utf8# The default character set that will be used when a new schema or table is# created and no character set is defineddefault-character-set=utf8

3、重新启动数据库。

MySQL 中文字符乱码问题

推荐:《mysql视频教程》

mysql数据表中文乱码解决办法

在往 mysql 数据库中插入数据的时候出现数据 ( 汉字 ) 乱码情况:

在把数据库,数据表的编码改为UTF-8后,还是乱码。

edf6ec50db88676d679cf576b002996.png

Mysql的默认编码方式是Latin1,不支持中文,因此,如果要让mysql支持中文的话需要把数据库默认的编码修改为gbk或者utf8。

1.查看数据库的编码方式

mysql>show variables like 'character%';

d675682626fb9400a08c4959ca9db20.png

上面的各种字符设置必须一致,只是简单的对数据库、数据表设置编码格式不能完全解决乱码问题,我是将上面的说有字符编码全设置为utf8后解决的乱码问题。

对上面的信息加以说明:

 | character_set_client:客户端请求数据的字符集(编码方式) | character_set_connection:从客户端接收到数据,再传输的字符集(建立连接使用的编码) | character_set_database:默认数据库的字符集,无论默认数据库如何改变,都是这个字符集;如果没有默认数据库,那就使用 character_set_server 指定的字符集, 这个变量建议由系统自己管理,不要人为定义。 | character_set_results:结果集的字符集 | character_set_server:数据库服务器的默认字符集 | character_set_system:这个值总是utf8,不需要设置,是存储系统元数据的字符集

上述变量的值不一致或者显示乱码时,可以通过如下命令来修改:

mysql> SET character_set_client = utf8; mysql> SET character_set_results = utf8; mysql> SET character_set_connection = utf8;

2、找到MySQL5.0安装目录下编辑打开my.ini文件,修改为:

[client]port=3306default-character-set=utf8[mysql]default-character-set=utf8# The default character set that will be used when a new schema or table is# created and no character set is defineddefault-character-set=utf8

3、重新启动数据库。

mysql数据库中文乱码怎么解决

乱码一般需要统一下字符集,比如设成UTF8。以下地方的字符集进行检查并统一:

    使用了CRT客户端的话,检查其字符集

    系统服务端字符集

    数据库客户端字符集,比如使用set names uft8;设置

    数据库服务端字符集,比如在my.cnf文件配置character-set-server=utf8

    数据库表的字符集

mysql8.0 中文数据乱码怎么解决

MySQL会出现中文乱码的原因不外乎下列几点:
1.server本身设定问题。
2.table的语系设定问题(包含character与collation)
3.客户端程式(例如php)的连线语系设定问题强烈建议使用utf8。utf8可以兼容世界上所有字符!
一、避免创建数据库及表出现中文乱码和查看编码方法
1、创建数据库的时候:CREATE DATABASE `test`
CHARACTER SET 'utf8'
COLLATE 'utf8_general_ci';
2、建表的时候 CREATE TABLE `database_user` (
`ID` varchar(40) NOT NULL default '',
`UserID` varchar(40) NOT NULL default '',
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
这2个设置好了,基本就不会出问题了,即建库和建表时都使用相同的编码格式。
但是如果已经建了库和表可以通过以下方式进行查询。

mysql8.0 中文数据乱码怎么解决

MySQL会出现中文乱码的原因不外乎下列几点:
1.server本身设定问题。
2.table的语系设定问题(包含character与collation)
3.客户端程式(例如php)的连线语系设定问题强烈建议使用utf8。utf8可以兼容世界上所有字符!
一、避免创建数据库及表出现中文乱码和查看编码方法
1、创建数据库的时候:CREATE DATABASE `test`
CHARACTER SET 'utf8'
COLLATE 'utf8_general_ci';
2、建表的时候 CREATE TABLE `database_user` (
`ID` varchar(40) NOT NULL default '',
`UserID` varchar(40) NOT NULL default '',
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
这2个设置好了,基本就不会出问题了,即建库和建表时都使用相同的编码格式。
但是如果已经建了库和表可以通过以下方式进行查询。

php读取mysql中文数据出现乱码的解决方法

1.PHP页面语言本身的编码类型不合适,这时候,你直接在脚本中写的中文肯定是乱码,不用说数据库了
解决方法:选择'UTF8'或者'gb2312',这样客户浏览器会自动选择并出现正确的中文显示。注意:'UTF8'或者'gb2312'都可以正确显示中文的。
2.数据库MySQL中的编码类型不正确。
解决方法:创建数据库的时候,MySQL
字符集选择'UTF8',MySQL
连接校对选择utf8_general_ci,这样创建的数据库用来存储中文肯定没有问题,
否则,你的中文首先在MySQL中就是乱码,更不要期望它会给你在PHP页面中显示正确。
3.与平时的脚本编辑环境有关。比如,有些内容是自己用word写的,有些是用记事本写的,有些用editplus、ultraplus等文本编辑器。有时候就直接在DW中写中文了,
解决方法:尽量用同一种编辑器。如果是拷贝来得既有的内容,建议用ultraplus中的编码转换功能把它转换成utf8或者gb2312。
到底转换成什么类型并不重要,关键要求你的PHP
WEB应用程序中的编码要一致就行。
4.编程访问
MySQL时,建议添加一行代码:mysql_query("SET
NAMES
'GBK'");

php读取mysql中文数据出现乱码的解决方法

1.PHP页面语言本身的编码类型不合适,这时候,你直接在脚本中写的中文肯定是乱码,不用说数据库了
解决方法:选择'UTF8'或者'gb2312',这样客户浏览器会自动选择并出现正确的中文显示。注意:'UTF8'或者'gb2312'都可以正确显示中文的。
2.数据库MySQL中的编码类型不正确。
解决方法:创建数据库的时候,MySQL
字符集选择'UTF8',MySQL
连接校对选择utf8_general_ci,这样创建的数据库用来存储中文肯定没有问题,
否则,你的中文首先在MySQL中就是乱码,更不要期望它会给你在PHP页面中显示正确。
3.与平时的脚本编辑环境有关。比如,有些内容是自己用word写的,有些是用记事本写的,有些用editplus、ultraplus等文本编辑器。有时候就直接在DW中写中文了,
解决方法:尽量用同一种编辑器。如果是拷贝来得既有的内容,建议用ultraplus中的编码转换功能把它转换成utf8或者gb2312。
到底转换成什么类型并不重要,关键要求你的PHP
WEB应用程序中的编码要一致就行。
4.编程访问
MySQL时,建议添加一行代码:mysql_query("SET
NAMES
'GBK'");

mysql插入的中文字符显示为乱码或问号怎么办

mysql中文显示乱码或者问号是因为选用的编码不对或者编码不一致造成的,最简单的方法就是修改mysql的配置文件my.cnf。在[mydqld]和[client]段加入

default-character-set=utf8

(有的版本不支持default-character-set=utf8,用character_set_server=utf8来取代 default-character-set=utf8即可)

注:如果没有[client]就手工加入[client]段

( 5.0以上版本修改方法:

修改/etc/my.cnf 中的设置,

在[client]节点下添加

default-character-set=utf8

在[mysqld]节点下添加

character-set-server=utf8

collation-server=utf8_general_ci

)

然后重启mysql即可

附关闭启动命令:(

[root@sg211 mysql-cluster]# bin/mysqladmin -u root -p shutdown;

[root@sg211 mysql-cluster]# bin/mysqld_safe --defaults-file=/opt/mysql-cluster/etc/my.cnf --basedir=/opt/mysql-cluster --datadir=/opt/mysql-cluster/data --user=mysql &

这时可以验证下是否生效

mysql> show variables like 'char%';

+--------------------------+------------------------------------------+

| 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 | /opt/mysql-cluster/share/mysql/charsets/ |

+--------------------------+------------------------------------------+

8 rows in set (0.00 sec)

可以 看出都已经更正为utf8了,这样新建立的数据库缺省就是UTF8编码了。

那么已经创建好的数据库及库中的表要如何更改为utf8呢?

用alter语句(修改数据库的字符集不会改变原有数据表的字符集)

utf8:

ALTER DATABASE `数据库` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci

ALTER TABLE `数据表` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci

gbk (包含gb2312):

ALTER DATABASE `数据库` DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci

ALTER TABLE `数据表` DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci

mysql中文数据乱码怎么解决

用记事本或UitraEdit打开mysql数据库安装目录下的my.ini文件打开, 然后Ctrl+F搜索default-character-set,将后面的字符集修改为UTF8,注意要修改两个地方,一个事客户端的,一个是服务端的。

然后保存,重启mysql服务、、进去继续用show variables like “%colla%”;show varables like “%char%”;着两条语句查询一下字符集。

mysql中文数据乱码怎么解决

用记事本或UitraEdit打开mysql数据库安装目录下的my.ini文件打开, 然后Ctrl+F搜索default-character-set,将后面的字符集修改为UTF8,注意要修改两个地方,一个事客户端的,一个是服务端的。

然后保存,重启mysql服务、、进去继续用show variables like “%colla%”;show varables like “%char%”;着两条语句查询一下字符集。

Mysql中文乱码问题,急求解决!!!

1.在插入数据库时,写语句set NAMES utf8就是说你连接插入都使用utf8格式2,如果前面方法不行的话,检查数据表是否为utf采用utf8格式,有时候数据表为utf8但是其中字段不一定是3,如果是输出到web的,还要查看页面是否设置了编码为utf8

Mysql中文乱码问题,急求解决!!!

1.在插入数据库时,写语句set NAMES utf8就是说你连接插入都使用utf8格式2,如果前面方法不行的话,检查数据表是否为utf采用utf8格式,有时候数据表为utf8但是其中字段不一定是3,如果是输出到web的,还要查看页面是否设置了编码为utf8

显示全文