疯狂java


您现在的位置: 疯狂软件 >> 新闻资讯 >> 正文

hibernate插入CLOB大数据类型


 

ibernateTemplate对CLOB对象操作,NoLobHandlerfoundforconfiguration...
利用HibernateTemplate对CLOB对象操作
Oracle中的varchar2对象最多只能存4000个字节,对于要进行大批量字符对象的存储来说显然是远远不够的,这时就需要用到CLOB。
Spring的HibernateTemplate的既有方法完全兼容对CLOB对象的操作,仅仅需要简单的配置:
1.保留实体中需要保存为CLOB对象的属性为String,而在hbm映射文件中将其修改为org.springframework.orm.hibernate3.support.ClobStringType
2.如果仅仅这样,会抛出异常:NoLobHandlerfoundforconfiguration-lobHandlerpropertymustbesetonLocalSessionFactoryBean
解决方法:
(1).声明一个处理句柄:
<beanid="lobHandler"class="org.springframework.jdbc.support.lob.DefaultLobHandler"lazy-init="true"/>
(2).在sessionFactory中注入lobHandler:
<beanid="sessionFactory"class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<propertyname="lobHandler"ref="lobHandler"/>
</bean>
提示:指定lobHandler时,对于MySQL、DB2、MSSQLServer、Oracle10g,使用DefaultLobHandler即可,而Oracle9i,
则可以使用OracleLobHandler。因为Oracle9i处理lob的方式和不太一样,所以这里要用spring提供的SimpleNativeJdbcExtractor.处理Oracle9ilob类型的特殊声明:
<beanid="nativeJdbcExtractor"lazy-init="true"class="org.springframework.jdbc.support.nativejdbc.
SimpleNativeJdbcExtractor"/>
<beanid="lobHandler"lazy-init="true"class="org.springframework.jdbc.support.lob.OracleLobHandler">
<propertyname="nativeJdbcExtractor">
<refbean="nativeJdbcExtractor"/>
</property>
</bean>
<beanid="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!--为处理Blob类型字段的句柄声明-->
<propertyname="lobHandler">
<reflocal="lobHandler"/>
</property>
</bean>