用tomcat从eclipse往mysql存中文变乱码解决办法

最近学习javaWEB遇到的一个比较大的问题,百度了好久,现将解决办法记录如下:

首先,判断mysql数据库的所有编码格式:(统一以utf-8格式举例)

进入自建库:

use 库名;

查看自建库的编码:

show variables like '%char%';

结果如下:(我是之前改过的)

修改图片中的红框编码:

set  character_set_database=utf8;
set  character_set_server=utf8;
set  character_set_system=utf8;

修改自建库的编码:

alter database 库名 character set utf8;

之后查看创建表的编码格式:

(如果新创建表,在创建表的sql语句后加charset=utf8;即可)

(如果已创建)查看表的编码格式

show create table 表名;

如果表的编码格式和每个字段的编码格式都是utf-8的话,那么来修改eclipse的编码。

如果没有,下行代码修改表中的字段编码:(基本上英文字母能存进数据库,而中文存不进的主要原因是字段编码)

alter table <表名> change <字段名> <字段名> <类型> character set utf8;

修改eclipse编码:

鼠标右击项目

修改项目的编码格式:

到现在基本上把所有的编码格式都改成utf-8了,还是存不进中文,想来想去还有一个地方没改------那就是tomcat

在创建eclise项目的时候都会生成一个servlets文件,如图:

右击该文件夹,同样打开下拉菜单的最后一项properties的地址选项:

 打开servlet文件夹,并在Tomcat文件目录下找servlet.xml文件,并打开:

在对应的属性下添加   URIEncoding=“utf-8”

 添加之后,存中文是乱码和存不进的问题就解决了。

猜你喜欢

转载自blog.csdn.net/Feng0811xin/article/details/85035465