在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 文档中有如何使用参数的例子。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)