有关mysql的乱码问题

今天在做web项目时,发现在插入数据库时出现了中文的乱码问题,在网上找了一大堆,无非就是一个问题,那就是数据库的编码设置有问题,在这里仅仅只是讲一下方法是怎么做的:

1.在MySQL中使用show Variables like 'char%'命令查看MySQL的编码格式,如果不是utf-8格式就全部都换成utf-8格式的,反正换成这个没啥错,具体等之后在深究;

2.直接了当在MySQL的安装目录下编辑my.ini文件

[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
default-character-set=utf8

有的就更改,没有就填上

之后,在写数据库的时候在CREATE DATABASE database_name default character set utf8 collate utf8_general_ci;加上这个

最后用show Variables like 'char%'得出这样:

就可以了。

3.这样MySQL就基本不抽风了,不过,我后来发现自己在前端jsp页面传入Controller的时候数据也出现了乱码,所以导致插入数据库的时候也是乱码形式,解决方法很简单,就是添加一个编码过滤器就行了

<filter>
  <filter-name>Spring character encoding filter</filter-name>
  <filter-class>
  org.springframework.web.filter.CharacterEncodingFilter
  </filter-class>
  <init-param>
  <param-name>encoding</param-name>
  <param-value>utf-8</param-value>
  </init-param>
 </filter>
 <filter-mapping>
  <filter-name>Spring character encoding filter</filter-name>
  <url-pattern>/*</url-pattern>
 </filter-mapping>

这样就全部解决了!!!

不得不说,这个编码的问题我一直很少涉及,也没有深究过,这次暴露出了很多问题,不过我只是有了解决方法,但是并不清楚原理,往后弄懂了原理再回来填坑。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值