我的是struts2+hibernate3+spring2+oracle 9,想实现的是将CLOB字段的类型入库,
但运行后出现如下错误信息:Active Spring transaction synchronization or active JTA transaction with specified
我的结构是这样的: 首先是HBM文件:
     <property name="content" type="org.springframework.orm.hibernate3.support.ClobStringType">
            <column name="CONTENT"  />
        </property>POJO里:private  String content;
为了方便,我这样搞,把基本的增删改等归纳到一个类里去了;
public class CommonServiceImpl extends HibernateDaoSupport implements
  CommonService 
{ /**
  * 保存对象
  *
  * @param temp
  * @param item
  * @return
  */
 protected Serializable save(HibernateTemplate temp, Object item) {
  return temp.save(item);
 }
}一个文章保存的实现类如下:
public class ArticleServiceImpl extends CommonServiceImpl implements IArticleService{。。一些其他逻辑方法
}
applicationContext.xml配置文件:
<bean id="lobHandler" lazy-init="true"   class="org.springframework.jdbc.support.lob.OracleLobHandler">
        <property name="nativeJdbcExtractor">
            <ref bean="nativeJdbcExtractor"/>
        </property>
</bean> <bean id="nativeJdbcExtractor" lazy-init="true"   class="org.springframework.jdbc.support.nativejdbc.SimpleNativeJdbcExtractor"/>  <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
 
  <property name="dataSource">
   <ref local="dataSource" />
  </property>
    <property name="lobHandler" ref="lobHandler"/>.....
</bean> 
<bean id="commonServiceImpl" class="com.trustel.service.CommonServiceImpl">
  <property name="sessionFactory">
   <ref local="sessionFactory" />
  </property>
 
 </bean> <bean id="commonService" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
  <property name="transactionManager">
   <ref bean="transactionManager" />
  </property>
  <property name="target">
   <ref local="commonServiceImpl" />
  </property>
  <property name="transactionAttributes">
   <props>
    <prop key="*">PROPAGATION_REQUIRED</prop>
   </props>
  </property>
 </bean>
 <bean id="txProxyTemplate" abstract="true" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
     <property name="proxyTargetClass">
      <value>true</value>
     </property>
     <property name="transactionManager">
      <ref bean="transactionManager"/>
     </property>
     <property name="transactionAttributes">
   <props>
          <prop key="*">PROPAGATION_REQUIRED,ISOLATION_DEFAULT,-Exception</prop>
      </props>
     </property>
 </bean>对于文章类的服务层配置如下:
<bean id="articleService"
  class="com.djs.um.service.article.impl.ArticleServiceImpl">
  <property name="articleDao">
   <ref bean="articleDao" />
  </property>
 </bean>
</beans>对于文章类的DAO层配置如下:
<bean id="articleDao" parent="txProxyTemplate">
     <property name="target">
       <bean class="com.djs.um.dao.impl.ArticleDaoImpl">
        <property name="sessionFactory">
    <ref bean="sessionFactory" />
   </property>
       </bean>
     </property>
   </bean>在STRUTS2的ACTION类中,只需要在代码里注入articleService就可以了。
奇怪的是,我只是配了CLOB才出现这个问题,不用的话其他运行一切正常。

解决方案 »

  1.   


    <property name="content" type="org.springframework.orm.hibernate3.support.ClobStringType">
                <column name="CONTENT"  />
            </property>换成<property name="content" type="text">
                <column name="CONTENT"  />
            </property>
      

  2.   

    用下面的代替试试<bean id="lobHandler" lazy-init="true"  class="org.springframework.jdbc.support.lob.DefaultLobHandler"/>
      

  3.   

    应该是你映射文件那个clob类型没有配置好 
      

  4.   

    <bean id="lobHandler" lazy-init="true"  class="org.springframework.jdbc.support.lob.OracleLobHandler"> 
            <property name="nativeJdbcExtractor"> 
                <ref bean="nativeJdbcExtractor"/> 
            </property> 
    </bean> 好象是在你的spring里面必须配置transaction 
    <bean id="txProxyTemplate" abstract="true" 
    class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"> 
        <property name="proxyTargetClass"> 
          <value>true </value> 
        </property> 
        <property name="transactionManager"> 
          <ref bean="transactionManager"/> 
        </property> 
        <property name="transactionAttributes"> 
      <props> 
              <prop key="*">PROPAGATION_REQUIRED,ISOLATION_DEFAULT,-Exception </prop> 
          </props> 
        </property> 
    </bean> 
     这里面注入SERVICE层 
      

  5.   

    定义这个lobHandler,值得注意的是这里有Oracle的版本区别:<bean id="lobHandler" lazy-init="true"   class="org.springframework.jdbc.support.lob.OracleLobHandler">
            <property name="nativeJdbcExtractor">
                <ref bean="nativeJdbcExtractor"/>
            </property>
    </bean><bean id="nativeJdbcExtractor" lazy-init="true"   class="org.springframework.jdbc.support.nativejdbc.SimpleNativeJdbcExtractor"/>因为Oracle9i处理Clob的方式和别的数据库很不一样,甚至与Oracle10g都不兼容
    http://www.matrix.org.cn/thread.shtml?topicId=f0170696-b81b-11db-82df-078095a5dcde&forumId=23
      

  6.   


    这些我都有了,但还是不行,我的是9I的,不能用DEFAULT那个