首先看一下由于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&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环境中出现的乱码问题。该问题通常出现在处理中文字符时,由于编码设置不当导致中文显示为乱码或无法正常读取。为了确保系统...
在开发Java Web应用程序时,经常会遇到编码问题,尤其是在使用Struts、Hibernate、MyEclipse、Tomcat和MySQL等技术栈时。这个问题主要涉及到各种组件之间的编码一致性,以及数据的正确转换。本文将针对这些技术的...
JavaWeb学生在线选课系统,使用了三大框架SSH Struts+Hibernate+Spring 编码格式是UTF-8,打开请注意调一下格式,如果出现乱码,请下载一个高级记事本例如Notepad+++直接打开 .java源文件 复制粘贴即可.内含数据库脚本...
总的来说,"Struts2+Spring2+Hibernate3整合的例子"是一个完整的Java Web开发示例,它展示了如何有效地组合这三个框架,实现MVC模式,解决中文乱码问题,并且通过Spring的管理,增强了代码的可维护性和可测试性。...
5. **设置字符集(Set Character Set)**: 设置项目的字符集为 UTF-8,以避免中文乱码的问题。 6. **添加 Struts 功能(Add Struts Capability)**: Struts 是一种流行的 MVC 框架,通过添加 Struts 功能,可以在 ...
综上所述,解决hibernate+mysql环境下中文存入数据库乱码的问题,需要从Web应用配置、数据库配置、框架配置以及文件编码等多个方面综合考虑,确保整个数据处理链路的字符集一致且支持UTF-8。只有这样,才能确保中文...
如果上面5步都没问题,你就不存在中文乱码问题。 ====================================================== 数据库使用的是MySQL,其版本为5.0.45 版本。 数据库的用户名及密码均为root。 使用的时候,请参考附件...
学生管理系统(Struts Hibernate mysql)无乱码问题。内附数据库文件,直接导入即可用。lib分成两个包lib1,lib2单独下载.把两个包一起搞到lib下即可。 这个是lib1包。你还要下载 学生管理系统(Struts Hibernate ...
在进行MySQL、JSP以及SSH(Struts、Spring、Hibernate)框架集成的网站开发时,中文乱码问题是一个常见的困扰。这通常是由于编码格式不一致、设置不当或处理方式错误导致的。以下是一些关键的知识点,可以帮助你解决...
在MySQL、JSP和SSH框架集成的网站开发过程中,中文乱码问题是一个常见的困扰。解决这个问题的关键在于确保整个系统从数据存储、页面显示到数据传输的编码一致性。以下是一个详细的解决方案: 1. **MySQL编码配置**...
总结来说,SSH框架的集成涉及到数据库连接、Hibernate配置、Spring容器设置、Struts2拦截器配置以及处理乱码和连接池问题。通过这些步骤,开发者可以构建一个完整的Java Web应用程序,实现MVC架构,有效地管理数据...
学生管理系统(Struts Hibernate mysql)无乱码问题。内附数据库文件,直接导入即可用。lib分成两个包lib1,lib2单独下载.把两个包一起搞到lib下即可。 这个是lib2包。你还要下载 学生管理系统(Struts Hibernate ...
开发语言:JAVA, 框架:SSH+Mysql+jsp (struts2 + spring + hibernate) 带有Mysql数据库和漂亮的后台管理功能 项目架构 开发环境:1. jdk1.6 2. myeclipse10 3. tomcat6 4. mysql utf-8 使用技术:1. ssh 框架...
在开发环境的部署中,选择了Ubuntu操作系统,并使用BootStrap前端框架来搭建用户界面,数据库选择MySQL 5.5,服务器则使用Tomcat,开发工具选择Myeclipse 10,并已经配置好Struts2和Hibernate环境。特别需要注意的是...
总结来说,J2EE项目中的编码问题涵盖Java的IO操作、HTTP通信、Struts框架的处理逻辑、MySQL数据库的存储以及Hibernate的数据映射。开发者需要对这些环节的编码解码规则有清晰的理解,以确保数据在整个生命周期中的...
- **Struts**:在Struts2的配置文件(如`struts.xml`)中,可以通过拦截器设置请求编码,以处理POST请求中的中文乱码。 ```xml <constant name="struts.action.encoding" value="utf-8"/> ``` - **Hibernate**...
在Java Web开发中,我们经常会遇到各种乱码问题,特别是在使用Hibernate、Struts和Spring等框架时。这些框架处理数据的方式以及与数据库交互的过程都可能导致字符编码不一致,从而引发乱码现象。以下是对这些技术全...
如果上面5步都没问题,你就不存在中文乱码问题。 ====================================================== 数据库使用的是MySQL,其版本为5.0.45 版本。 数据库的用户名及密码均为root。 使用的时候,请参考附件...
8. **解决MySQL乱码问题**:在数据库连接URL中加入`useUnicode=true&characterEncoding=UTF-8`参数,确保数据在存储和读取时正确处理UTF-8编码。同时,确保项目中的字符集配置一致,如Web.xml、struts.properties等...
学生管理系统(Struts Hibernate mysql)无乱码问题。内附数据库文件,直接导入即可用。lib分成两个包lib1,lib2单独下载.把两个包一起搞到lib下即可。我看到很多朋友只下载lib包,这个才是源码包。