用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”

 

 

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

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值