服务器之家

服务器之家 > 正文

浅谈mysql的中文乱码问题

时间:2020-04-30 15:12     来源/作者:MYSQL之家

首先,我用的mysql版本号是5.5.17的,最近遇到的问题是在eclipse中通过jdbc往数据库写中文数据的时候,在数据库中显示的是??即乱码,为解决这个问题,搞了一个晚上(当然熄灯后就就寝了(__) )外加早上这会儿,搞得头都大了,改来改去导致连往数据库直接写中文都会报错(我把错误页贴出来吧)如下:

浅谈mysql的中文乱码问题

其实现在回头看看,乱码无非是改一下mysql安装文件中的my.ini文件以及data中的db.opt文件,具体修改如下:

将my.ini文件中的文件修改为:

?
1
2
3
4
5
6
7
8
9
[client]
port=3306
 
[mysql]
 
default-character-set=gbk
 
[mysqld]
character-set-server=utf8

现在需要将data中的db.opt修改一下:

default-character-set=utf8
default-collation=utf8_general_ci

好了,现在修改文件完毕,现在需要重写启动mysql服务,进入mysql后输入命令:

show variables like “%colla%”;

然后再输入show varables like “%char%”;
如果以上结果和下图相同那就设置成功了

浅谈mysql的中文乱码问题

浅谈mysql的中文乱码问题

另外,以后如果再遇到从eclipse中往数据库写中文数据出sql异常时可以先在cmd中输入命令:

show create database db;(db为数据库名)可以查看数据库的编码,如果还是latin1,可使用以下命令修改数据库编码:
alter database db default character set utf8;

这样就可以将数据库的编码改为utf8了。

此时,再通过jdbc连接时,就可以很随意的添加中文到mysql中了。

以上便是我在使用mysql中遇到的乱码问题,希望能给遇到相同问题的同学少走弯路提供一点参考。。。

请您花一点时间将文章分享给您的朋友或者留下评论。我们将会由衷感谢您的支持!

标签:

相关文章

热门资讯

沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意
沙雕群名称大全2019精选 今年最火的微信群名沙雕有创意 2019-07-07
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
超A是什么意思 你好a表达的是什么
超A是什么意思 你好a表达的是什么 2019-06-06
和平精英超高音质怎么修改 和平精英超高音质重启设置方法
和平精英超高音质怎么修改 和平精英超高音质重启设置方法 2019-06-26
返回顶部