数据存入mysql后乱码_聊聊数据保存到MySQL后数据乱码的问题

经常我们会碰到数据乱码的问题,有页面乱码,java运行时变量里的数据乱码,数据库表数据乱码。我今天主要说说我在工作中遇到的数据库表数据乱码问题怎么解决。

当我们表里数据保存后发现乱码,首先我们要确定数据的来源以及中间处理层的字符集编码是不是一致,比如我们用java从文件中读取一段utf-8的文字然后保存到数据库中时,首先我们得用utf-8编码读取并用utf-8保存到数据库中。也就是说java应用层和数据库的编码必须一致才不会出现乱码。

应用层的编码我们暂时不说,我主要分享一下mysql数据库中的乱码如何解决,关于乱码为什么会出现或者说原理我也讲不通,给个链接,大家自己看,乱码是怎么形成的?

我们出现在数据库乱码时,先确定是不是java层就乱码了,如果不是,那肯定是数据到数据库层才乱码的。所以我们需要再次确认数据库层的每个过程都是utf-8(我们以utf-8编码为例,你用gbk也是可以的),下面就看看怎么看数据库每个有可能造成乱码的地方:

一、MySQL全局编码配置

mysql的全局变量可以通过命令来修改,也可以在my.cnf(windows下配置文件为my.ini)中配置,内容如下:

[mysqld]

character-set-server=utf8

collation_server=utf8_general_ci

[client]

default-character-set=utf8

[mysql]

default-character-set=utf8

如上my.cnf的编码配置,如果我们java读取的文件是utf-8࿰

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值