`
noblemoon
  • 浏览: 25456 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

hibernate访问oracle乱码问题

阅读更多
oracle的字符集是WE8ISO8859P1,由于历史原因,不可修改。已经修改本地
NLS_LANG:
1.通过执行select NLS_LANGUAGE, NLS_ISO_CURRENCY,NLS_CHARACTERSET from V$NLS_PARAMETERS查看服务端字符集

2.通过regedit修改注册表(仅讨论windows版)进行客户端的字符集,位置\HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOME0\NLS_LANG修改为[NLS_LANGUAGE]_[NLS_ISO_CURRENCY].[NLS_CHARACTERSET]

因此使用PL/SQL developer可以正常访问。
但是 hibernate使用thin方式连接数据库,中文乱码。
为了使页面可以正常显示,在取数据时在form的get方法中使用
String new_str = new String(old_str.getBytes("iso-8859-1"));
得到的new_str可以正常显示中文。
但是这样增加了冗余代码,而且使用好多第三方组件时,由于无法控制转码细节,导致乱码。
在互联网上搜索解决方案,搜到的大多是一个方法,加入filter,使用org.springframework.web.filter.CharacterEncodingFilter
但是对我这个情况完全无效,存取数据都是乱码,存到数据库里的数用客户端看也是乱码。
我觉得CharacterEncodingFilter应该是在oracle的字符集正确设置的情况下,比如使用ZHS16GBK,解决乱码的问题。
现在请教各位高手有没有遇到过同样的问题,如何解决这种情况下的乱码。是否需要写一个filter或者是hibernate直接可以对oracle字符集进行配置。


问题已经解决,说一下我的解决方案吧。使用hibernate的UserType 在hbm.xml中配置,比如
<property name="roleName" type="com.xtmcc.framework.dao.GBKString">
<column name="ROLE_NAME" length="50" />
</property>
自定义GBKString 类
package com.xtmcc.framework.dao;

import java.io.Serializable;
import java.io.UnsupportedEncodingException;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
  
import oracle.jdbc.driver.OracleTypes;
  
import org.apache.commons.lang.builder.HashCodeBuilder;
import org.hibernate.HibernateException;
import org.hibernate.usertype.UserType;

public class GBKString implements UserType {

public GBKString() {
super();
}
  
public int[] sqlTypes() {
return new int[] { OracleTypes.VARCHAR };
}
  
public Class returnedClass() {
return String.class;
}
  
public boolean equals(Object x, Object y) throws HibernateException {
return (x == y) || (x != null && y != null && (x.equals(y)));
}
  
public Object nullSafeGet(ResultSet rs, String[] names, Object owner) throws HibernateException,
SQLException {
String val = rs.getString(names[0]);
if (null == val) {
return null;
} else {
try {
val = new String(val.getBytes("iso-8859-1"), "GBK");
} catch (UnsupportedEncodingException e) {
throw new HibernateException(e.getMessage());
}
return val;
}
}
  
public void nullSafeSet(PreparedStatement st, Object value, int index) throws HibernateException,
SQLException {
if (value == null) {
st.setNull(index, OracleTypes.VARCHAR);
} else {
String val = (String)value;
try {
val = new String(val.getBytes("GBK"), "ISO_8859_1");
} catch (UnsupportedEncodingException e) {
throw new HibernateException(e.getMessage());
}
st.setObject(index, val, OracleTypes.VARCHAR);
}
}
public Object deepCopy(Object value) throws HibernateException {
if (value == null)
return null;
return new String((String) value);
}
  
public boolean isMutable() {
return false;
}
  
public Object assemble(Serializable arg0, Object arg1) throws HibernateException {
// TODO Auto-generated method stub
return null;
}
  
public Serializable disassemble(Object arg0) throws HibernateException {
// TODO Auto-generated method stub
return null;
}
  
public int hashCode(Object arg0) throws HibernateException {
return HashCodeBuilder.reflectionHashCode(this);
}
  
public Object replace(Object arg0, Object arg1, Object arg2) throws HibernateException {
// TODO Auto-generated method stub
return null;
}

}


分享到:
评论

相关推荐

    SQL-SERVER-64位配置ORACLE连接-中文乱码问题

    ### SQL-SERVER-64位配置ORACLE连接-中文乱码问题 在IT行业中,不同数据库之间的连接配置是一项常见的任务,特别是在需要实现跨平台数据交换的场景下。本文将详细介绍如何解决64位系统下的SQL Server连接Oracle...

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

    总结来说,SSH框架的集成涉及到数据库连接、Hibernate配置、Spring容器设置、Struts2拦截器配置以及处理乱码和连接池问题。通过这些步骤,开发者可以构建一个完整的Java Web应用程序,实现MVC架构,有效地管理数据...

    HibernateOracle

    在开发Java Web应用程序时,有时会遇到中文数据在Hibernate与Oracle数据库交互时出现乱码的问题。这通常是由于字符集不匹配或处理方式不当所引起的。本文将深入探讨这个问题,并提供解决方案。 首先,我们需要理解...

    关于Hibernate3中文查询出错问题的解决

    在使用Hibernate3进行数据库操作时,中文查询出错是一个常见的问题,这主要涉及到字符编码、数据库配置以及Hibernate的设置等多个方面。以下将详细介绍如何解决这个问题。 首先,我们要明白错误的根源通常在于字符...

    hibernate存取汉字小程序

    【hibernate存取汉字小程序】是一个典型的Java开发项目,主要使用了Eclipse IDE、Hibernate3 ORM框架以及Oracle数据库来处理中文字符的问题。在实际的软件开发中,尤其是在与数据库交互时,处理中文字符可能会遇到...

    SSH框架解决中文乱码

    在开发基于SSH(Struts2 + Spring + Hibernate)框架的应用程序时,经常会遇到中文乱码的问题。这些问题主要出现在两个方面:一是前端页面上中文字符显示不正常;二是向数据库(如Oracle)中插入包含中文的数据时...

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

    所以要完成对Lob字段的操作,Hibernate必须执行两步数据库访问操作,先Insert再Update。  使用BlobByteArrayType字段类型后,为什么我们就可以象一般的字段类型一样操作Blob字段呢?可以确定的一点是:...

    Eclipse创建的JSP文件链接SQLServer2012,Oracle,mysql的方法.rar

    此外,还可以使用DAO(数据访问对象)模式或ORM(对象关系映射)框架如Hibernate或MyBatis来简化数据库操作。 文档中会详细列出每一步操作的步骤,包括配置数据库连接字符串、编写JDBC代码示例以及处理异常的技巧。...

    数据库迁移及区别比较(Oracle,Sql Server,MySql).docx

    2. **数据导入与编码设置**:确保数据库编码正确,防止中文等多语言数据出现乱码。这可能需要修改数据库配置文件或使用SQL命令来设置字符集。例如,对于MySQL,可以设置`default-character-set`为`utf8`。 3. **...

    数据库迁移及区别比较(Oracle,Sql Server,MySql).pdf

    - 防止中文乱码:可以通过修改MySQL配置文件或在命令行中设置字符集,确保数据库支持UTF-8编码。 - 数据类型兼容性:如SQL Server的bit类型在MySQL中需转换为tinyint(1)。 3. **SQL语句的修改**: - 项目中的SQL...

    64位weblogic--windows安装部署及常见问题解决

    - 乱码问题:检查字符集设置,确保在服务器和应用中都正确配置了字符编码。 - MIME-Type配置问题:在WebLogic服务器配置中添加或修改MIME-Type映射。 - 应用不存在:确认部署的应用是否已成功上传到WebLogic并正确...

    JAVA面试笔试问题

    1. **中文乱码问题**:在Java中,当页面输入的中文传到后台数据库出现乱码,解决方法是通过创建一个过滤器(Filter),继承自HttpServlet,实现Filter接口,并重写doFilter方法。在该方法内,使用`request.set...

    Maven + Tapestry5.3.8 + Spring4.0.5 + Oracle10g

    这是Tapestry5.3.8 版本的一个大Demo,集合Spring4.0, 采用Maven 项目管理工具,没有集合Hibernate。 之所以说是个大Demo,是因为这项目中包含的内容并不少,包含: 1)解决了Tapestry5.3.8中文Bug问题 2)Tapestry...

    BOS 技术整理

    基于工具使用 SQL 插入中文有乱码问题,设置客户端字符集 gb2312 配置 环境变量 NLS_LANG = SIMPLIFIED CHINESE_CHINA.ZHS16GBK 弹窗了,就表示成功了! 工具补充: Navicat Premium 安装和使用 ...

    java基础知识 jspPPT 让你了解jsp基础

    - GET请求的乱码问题,可以通过将接收到的字节流转换为字符串时指定正确的字符编码来解决,例如从ISO-8859-1转为GBK。 - POST请求的乱码问题,需要在接收请求前设置字符编码,如`request.setCharacterEncoding(...

    J2EE面试必须掌握知识点

    注意:如果传递的值包含中文,需要进行字符编码和解码,以防止乱码问题。例如,使用 `URLEncoder.encode()` 编码和 `URLDecoder.decode()` 解码。 在面试中,对这些知识点的深入理解和灵活运用,能够展示你对J2EE...

    许愿墙程序 JAVA struts

    描述中提到的“乱码问题”通常涉及到字符编码。在JAVA Web开发中,UTF-8是最常用的编码格式,需要确保在服务器端、HTML页面、请求参数以及数据库连接配置中统一使用UTF-8,避免在传输和显示过程中出现乱码。 **5. ...

Global site tag (gtag.js) - Google Analytics