将文本文件写入Hibernate的CLOB字段,中文乱码怎么解决

将文本文件写入Hibernate的CLOB字段,中文乱码怎么解决,第1张

在spring中采用OracleLobHandler来处理oracle大字段(包括clob和blob),则在程序中不需要引用oracle的特殊类,从而能够保证支持代码支持多数据库。

在Spring的主配置文件xx.xml中的配置SessionFactory的bean中配置:

<bean id="nativeJdbcExtractor"

class="org.springframework.jdbc.support.nativejdbc.CommonsDbcpNativeJdbcExtractor"

lazy-init="true" autowire="default" dependency-check="default"/>

<bean id="oracleLobHandler"

class="org.springframework.jdbc.support.lob.OracleLobHandler"

lazy-init="true" autowire="default" dependency-check="default">

<property name="nativeJdbcExtractor" ref="nativeJdbcExtractor"/>

</bean>

<bean id="sessionFactory"

class="org.hibernate.cfg.SWSSessionFactoryBean" lazy-init="false"

autowire="default" dependency-check="default">

...

<property name="lobHandler">

<ref bean="oracleLobHandler"/>

</property>

...

</bean>

nativeJdbcExtractor和 lobHandler 设置为 lazy-init="true",

因为 nativeJdbcExtractor需要通过运行期的反射机制获取底层的 JDBC 对象,

所以需要避免在 Spring 容器启动时就实例化这两个 Bean。

<注:上面的SWSSessionFactoryBean是被重写过的,继承AnnotationSessionFactoryBean>

1、首先数据表中的clob类型对应java持久化类的String类型;而blob类型对应byte[]类型

2、1.定义

hibernate标签时,持久化类中对应clob类型的属性的hibernate

type应为org.springframework.orm.hibernate.support.ClobStringType;而对应blob类型

的属性的hibernate

type应为org.springframework.orm.hibernate.support.BlobByteArrayType。

2.如果通过spring 注解功能配置PoJo类时,在该大字段属性的getXXX()方法前面加上注解:

public String xxx

...

@Lob

@Type(type="org.springframework.orm.hibernate3.support.ClobStringType")

@Column(length=10000)

public String getXXX ()

{

return xxx

}

常见是表的字段是非字符类型,引起长度问题,查看一下该字段的类型是否文字类型,如char,vchar,text……。

还有Hibernate的String默认生成的表字段长度是255,不要超过这长度,要么就设置长度,不使用默认长度。

添加中文乱码不是mysql的问题,hibernate和什么数据库都有这个问题,原因是hibernate在存储中文时,中文在内存中的存在方式的高低位和英文不同。所以,在hibernate中,如果向数据库存放数据中含有中文,那么就要使用把中文一参数的形式放入数据库中,hibernate 文档中有如何使用参数的例子。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11465600.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存