`
ReaiJava
  • 浏览: 20538 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

Sturts2+Hibernate3+MySql中文乱码问题处理总结

阅读更多

首先看一下由于MySql中文乱码而导致的问题:
1.java中处理插入中文数据字符正常,在DOS MySql client中显示数据字符集乱码的问题(修改client编码)

2.字段长度设置够长,但插入中文字符时提示Data truncation: Data too long for column 'username' at row 1 错误是字符集的问题.

3.乱码问题归根到底是字符集的问题,那就从字符集设置方面考虑,不外乎下面几个方面:jsp页面编码设置,mysql server/client/database/connection/results编码设置

我的数据库使用是GBK编码,也就拿GBK的编码设置为例,也可用UTF-8,不管你使用什么编码只要字符集编码设置统一就OK

(1)检查mysql安装目录下的配置文件my.ini(MySQL Server Instance Configuration 文件)

(my.ini文件默认目录C:\Program Files\MySQL\MySQL Server 5.0\my.ini)

[client]
port=3306
[mysql]
default-character-set=GBK(如果你的不是GBK编码格式改为GBK)

[mysqld]
port=3306
default-character-set=GBK(如果你的不是GBK编码格式改为GBK)

 

在创建数据库时最好设置好要使用的数据库编码 例create datebase YouDB character set gbk;

如果建数据库时没有设置编码查看一下MySQL Server 5.0\data目录下的数据库中的db.opt中的编码(不是GBK编码格式改为GBK)

default-character-set=gbk
default-collation=gbk_chinese_ci

  

也可用mysql dos cmd 界面查看 编码设置

mysql> show variables;
+---------------------------------+-------
| Variable_name                   | Value
+---------------------------------+-------
| character_set_client            | gbk     告诉mysql 客户端发送的查询SQL语句中使用GBK编码
| character_set_connection   | gbk     告诉mysql 要把SQL语句转换成GBK进行处理
| character_set_database     | gbk     告诉mysql 数据库要使用GBK编码

| character_set_results         | gbk     告诉mysql 查询返回结果要都统一转换成GBK编码格式

| character_set_server          | gbk     告诉mysql 服务器使用GBK编码
| character_set_system         | utf8    指的是数据库中存储元信息使用的字符集

 

(2)检查你的jsp页面编码设置

<%@ page language="java" import="java.util.*" pageEncoding="GBK"%>设置文件的编码
<meta http-equiv="content-type" content="text/html; charset=GBK">设置内容编码

  

(3)检查你的jsp的页面form提交到控制action时编码设置,在此我使用的是Sturts2在sturts.xml配置文件中加入

 <constant name="struts.i18n.encoding" value="GBK" />

 

(4)检查你的数据库连接(连接characterEncoding=GBK设置成GBK格式)

jdbc:mysql://localhost:3306/foodmould?useUnicode=true&amp;characterEncoding=GBK

 

 如果上述这几个地方编码设置都统一,应该就没有什么问题了。

 

MYSQL DOS 一些常用命令:
mysql -h主机地址 -u用户名 -p密码 连接MYSQL; (例:mysql -h110.110.110.110 -Uroot -P123456 注:u与root可以不用加空格,其它也一样) 

mysql> show variables;查看具体的服务器系统变量和值
mysql> show variables like 'charac%';可用模糊查询查看的服务器系统变量和值
mysql>use mydatebase; 使用mydatebase数据库
mysql>show tables; 显示数据库中的所有表
mysql>desc mytable;查看mytable表中的字段信息
mysql>describe mytable; 查看mytable表中的字段信息
mysql>drop table mytable; 删除mytable表 
mysql>delete from mytable;删除表mytable中所有记录
mysql>drop database mydb;删库mydb数据库
mysql>exit;退出MYSQL dos

 

 

MYSQL字符集相关各变量的意义

character_set_client: 客户端字符集(应用程序客户端使用的字符集),实际上它与当前会话相关。
character_set_connection: 连接字符集,指的是mysql网络传输操作中使用的字符集,也与会话相关。
character_set_database: 指的是数据库表中物理存储使用的字符集。
character_set_results: 指的是使用sql查询处理以后返回结果使用的字符集。
character_set_server:指的是mysql数据库服务器端使用的字符集。
character_set_system:指的是数据库中存储元信息使用的字符集。

 

分享到:
评论

相关推荐

    Struts+Hibernate+MyEclipse+Tomcat+MySQL的乱码之解决篇

    Struts Hibernate MyEclipse Tomcat MySQL JSP 乱码 编码出错 内码设定

    Struts+Hibernate+MyEclipse+Tomcat+MySQL的乱码之解决

    显示界面,JSP 2.0 JAVA容器:Tomcat 5.X MVC构架:Struts 1.2 ORM工具:Hibernate 3 数据库:MySQL 5.0 编译IDE:MyEclipse 5.0

    Struts2+Spring2+Hibernate3整合的例子.rar

    Struts2+Spring2+Hibernate3整合的例子,含mysql数据库,解决了关于utf-8中文乱码问题

    JavaWeb学生在线选课系统Struts+Hibernate+Spring

    JavaWeb学生在线选课系统,使用了三大框架SSH Struts+Hibernate+Spring 编码格式是UTF-8,打开请注意调一下格式,如果出现乱码,请下载一个高级记事本例如Notepad+++直接打开 .java源文件 复制粘贴即可.内含数据库脚本...

    网上书店系统(Struts+Hibernate)(Java EE项目案例)

    如果上面5步都没问题,你就不存在中文乱码问题。 ====================================================== 数据库使用的是MySQL,其版本为5.0.45 版本。 数据库的用户名及密码均为root。 使用的时候,请参考附件...

    学生管理系统(Struts Hibernate mysql)lib1

    学生管理系统(Struts Hibernate mysql)无乱码问题。内附数据库文件,直接导入即可用。lib分成两个包lib1,lib2单独下载.把两个包一起搞到lib下即可。 这个是lib1包。你还要下载 学生管理系统(Struts Hibernate ...

    学生管理系统(Struts Hibernate mysql)lib2

    学生管理系统(Struts Hibernate mysql)无乱码问题。内附数据库文件,直接导入即可用。lib分成两个包lib1,lib2单独下载.把两个包一起搞到lib下即可。 这个是lib2包。你还要下载 学生管理系统(Struts Hibernate ...

    struts-hibernate-sprint开发详解 乱码问题 连接池

    不会让大家后悔,里面介绍了连接池,dbutils的应用,struts-hibernate-sprint结合开发的实例详解,用的是sql server数据库,也可以改为mysql oracle只要改变数据库连接驱动和url即可。

    个性化定制系统(Ajax+Spring+Hibernate)(Java EE项目案例)

    如果上面5步都没问题,你就不存在中文乱码问题。 ====================================================== 数据库使用的是MySQL,其版本为5.0.45 版本。 数据库的用户名及密码均为root。 使用的时候,请参考附件...

    JAVA全部帮助文档

    《Struts中文帮助文档》的相关内容相关讨论struts+hibernate+mysql中文乱码解决struts

    学生管理系统(Struts Hibernate mysql)源码包

    学生管理系统(Struts Hibernate mysql)无乱码问题。内附数据库文件,直接导入即可用。lib分成两个包lib1,lib2单独下载.把两个包一起搞到lib下即可。我看到很多朋友只下载lib包,这个才是源码包。

    大学生毕设+基于JavaWeb带GUI界面+花店管理系统(前后端源码+数据库)

    网上花店(flower) 功能简介: 1, 支持商品展示, 分类搜索查看详情等 ...3, 请保证数据库默认编码为utf8, 否则可能会出现中文乱码问题 4, 项目简陋, 仅供学习参考, 如有任何问题请旺旺联系 测试用户: 前台1/1 后台1

    spring3.0、struts2.2.3、hibernate3.6.7整合完美jar包

    完美ssh新版本整合 解决了jar冲突和mysql乱码问题

    公告管理系统(JSP+Struts)(Java EE项目案例)

    如果上面5步都没问题,你就不存在中文乱码问题。 ====================================================== 数据库使用的是MySQL,其版本为5.0.45 版本。 数据库的用户名及密码均为root。 使用的时候,请参考附件...

    从J2SE到J2EE知识点介绍

    5. JSP页面通过URL传递中文参数的乱码问题 139 四、 Struts2 140 (一) 基于struts2的web应用的开发步骤 140 1. MVC设计模式() 140 2. 基于struts的web应用的开发步骤 141 3. 如何写自定义action,实体,以及业务类...

    网上文件管理系统(Struts)(Java EE项目案例)

    如果上面5步都没问题,你就不存在中文乱码问题。 ====================================================== 数据库使用的是MySQL,其版本为5.0.45 版本。 数据库的用户名及密码均为root。 使用的时候,请参考附件...

    ssh(structs,spring,hibernate)框架中的上传下载

     需要指定的是Spring 1.2.5提供了两套Hibernate的支持包,其中Hibernate 2相关的封装类位于org.springframework.orm.hibernate2.*包中,而Hibernate 3.0的封装类位于org.springframework.orm.hibernate3.*包中,...

    《MyEclipse 6 Java 开发中文教程》前10章

    第一章 安装配置开发环境 18 1.1系统需求 18 1.2 JDK 的下载,安装和配置(可...10.7.2 MyEclipse生成的Spring+Hibernate无法保存数据问题的解决方法2 - 用 CGLIB 来实现事务管理 258 10.7.3 Spring相关的参考资料 261

    java财务系统源代码

    前后台架构: 1、java语言(jdk1.5)、struts1.2.9、hibernate3.2.6.ga、spring2.0.8 2、前台:主要使用了轻量级的ajax开发框架jQuery,使用jQuery很轻松的降低了服务器压力提高了用户体验并且代码容易维护,尤其是...

Global site tag (gtag.js) - Google Analytics