首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

转载:CLOB,BLOG寸楷段加载

2012-11-09 
转载:CLOB,BLOG大字段加载Oracle中的varchar2对象最多只能存4000个字节,对于要进行大批量字符对象的存储来

转载:CLOB,BLOG大字段加载
Oracle中的varchar2对象最多只能存4000个字节,对于要进行大批量字符对象的存储来说显然是远远不够的,这时就需要用到CLOB。

Spring的HibernateTemplate的既有方法完全兼容对CLOB对象的操作,仅仅需要进行简单的配置:

1.保留实体中需要保存为CLOB对象的属性为String,而在hbm映射文件中将其修改为org.springframework.orm.hibernate3.support.ClobStringType

2.如果仅仅这样,会抛出异常:No LobHandler found for configuration - lobHandler property must be set on LocalSessionFactoryBean

解决方法:

(1).声明一个处理句柄:
<bean id="lobHandler" lazy-init="true" />
(2).在sessionFactory中注入lobHandler:
<bean id="sessionFactory" ref="lobHandler"/>
</bean>

提示: 指定lobHandler时,对于MySQL、DB2、MS SQL Server、Oracle 10g,使用DefaultLobHandler即可,而Oracle 9i,
则可以使用OracleLobHandler。因为Oracle9i处理lob的方式和不太一样,所以这里要用spring提供的SimpleNativeJdbcExtractor.处理Oracle9i lob类型的特殊声明:

<bean id="nativeJdbcExtractor" lazy-init="true" lazy-init="true"   />
</property>
</bean>

同时还应该使用对应的JDBC驱动。
如果是10g数据库 CLOB保存不报错,而加载为空的话,则一定要换一个最新的ojdbc.jar包,这样方可保证驱动正确


热点排行