最近学习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文件,并打开: