mysql中文问题终极解决方案
2009-03-20 09:21
288 查看
首先看一下由于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 指的是数据库中存储元信息使用的字符集
也可用命令:status查看
可以用set命令来设置编码
(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格式)
Java代码
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:指的是数据库中存储元信息使用的字符集。
<7>采用过滤器实现中文的处理的方法如下:
1, mysql安装时设置字符集utf-8, jdbc驱动3.0.15以上.
2. hibernate配置文件中,加上属性
<property name="connection.useUnicode">true</property>
<property name="connection.characterEncoding">UTF-8</property>
3. web.xml设置Filter
<filter>
<filter-name>
Set Web Application Character Encoding
</filter-name>
<filter-class>cn.com.commnet.util.SetEncodeFilter</filter-class>
<init-param>
<param-name>defaultencoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>
Set Web Application Character Encoding
</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
SetEncodeFilter.java
public class SetEncodeFilter implements Filter
{
protected FilterConfig filterConfig = null;
protected String defaultEncoding = null;
/**//* (non-Javadoc)
* @see javax.servlet.Filter#init(javax.servlet.FilterConfig)
*/
public void init(FilterConfig arg0) throws ServletException
{
// TODO Auto-generated method stub
this.filterConfig = arg0;
this.defaultEncoding = filterConfig.getInitParameter("defaultencoding");
}
/**//* (non-Javadoc)
* @see javax.servlet.Filter#doFilter(javax.servlet.ServletRequest, javax.servlet.ServletResponse, javax.servlet.FilterChain)
*/
public void doFilter(
ServletRequest request,
ServletResponse response,
FilterChain chain)
throws IOException, ServletException
{
// TODO Auto-generated method stub
request.setCharacterEncoding(selectEncoding(request));
chain.doFilter(request, response);
}
public void destroy()
{
this.defaultEncoding = null;
this.filterConfig = null;
}
protected String selectEncoding(ServletRequest request)
{
return this.defaultEncoding;
}
}
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 指的是数据库中存储元信息使用的字符集
也可用命令:status查看
可以用set命令来设置编码
(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格式)
Java代码
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:指的是数据库中存储元信息使用的字符集。
<7>采用过滤器实现中文的处理的方法如下:
1, mysql安装时设置字符集utf-8, jdbc驱动3.0.15以上.
2. hibernate配置文件中,加上属性
<property name="connection.useUnicode">true</property>
<property name="connection.characterEncoding">UTF-8</property>
3. web.xml设置Filter
<filter>
<filter-name>
Set Web Application Character Encoding
</filter-name>
<filter-class>cn.com.commnet.util.SetEncodeFilter</filter-class>
<init-param>
<param-name>defaultencoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>
Set Web Application Character Encoding
</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
SetEncodeFilter.java
public class SetEncodeFilter implements Filter
{
protected FilterConfig filterConfig = null;
protected String defaultEncoding = null;
/**//* (non-Javadoc)
* @see javax.servlet.Filter#init(javax.servlet.FilterConfig)
*/
public void init(FilterConfig arg0) throws ServletException
{
// TODO Auto-generated method stub
this.filterConfig = arg0;
this.defaultEncoding = filterConfig.getInitParameter("defaultencoding");
}
/**//* (non-Javadoc)
* @see javax.servlet.Filter#doFilter(javax.servlet.ServletRequest, javax.servlet.ServletResponse, javax.servlet.FilterChain)
*/
public void doFilter(
ServletRequest request,
ServletResponse response,
FilterChain chain)
throws IOException, ServletException
{
// TODO Auto-generated method stub
request.setCharacterEncoding(selectEncoding(request));
chain.doFilter(request, response);
}
public void destroy()
{
this.defaultEncoding = null;
this.filterConfig = null;
}
protected String selectEncoding(ServletRequest request)
{
return this.defaultEncoding;
}
}
相关文章推荐
- MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法[转贴]
- Mac 下 MySQL 5.7 连接 navicat 中文乱码问题终极解决方案
- MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法[转贴]
- MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法[转贴]
- MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法[转贴]
- MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法[转贴]
- C#(WinForm) + MySQL的中文编码问题(MySQL中文编码的终极解决方案)
- MySQL字符集中文乱码终极解决方案和mysql查询中文问题解决方法[转贴]
- mysql5.1 中文 乱码 mysql 5.1 中文字符集问题终极解决方案
- mysql 5.1 中文字符集问题终极解决方案
- Tomcat+MySql+Struts中文问题绝妙的解决方案
- JSP中文乱码问题终极解决方案
- POST/GET中文问题终极解决方案
- struts中文问题国际化问题终极解决方案
- 【mysql】Mysql中文乱码问题完美解决方案
- Mysql中文乱码问题完美解决方案[转]
- mysql 中文乱码问题的解决方案
- Mysql5.5中文问题完美解决方案
- Mysql中文乱码问题完美解决方案
- 关于mysql无法添加中文数据的问题以及解决方案