Struts2 blob(转)

最近在项目中第一次使用 struts2,在将文件上传到数据库(oracle9i)中时,出现了一个奇怪的问题,就是当上传的文件比较小时(先这样说,因为没有查阅相关文档也没有测试这个值为多少),可以正常上传到数据库中,但当我上传了一个为300多K的图片是出现如下错误:
     不允许的操作: streams type cannot be used in batching
    在网上查阅时,有个哥们做出了如下解释:
    

引用
近日程序的数据库转为oracle 在操作blob类型时报以下错误:不允许的操作: streams type cannot be used in batching。经过查找多方面的资料查证Oracle JDBC不允许流操作以批量方式执行(Oracle CLOB采用流机制作为数据读写方式)。 只需在spring配置文件中更改hibernate jdbc.batch_size为0即可。
    
Xml代码 复制代码
  1. <bean id="oracleSessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">      
  2.         <property name="dataSource">      
  3.             <ref bean="oracleDataSource"/>      
  4.         </property>      
  5.         <property name="hibernateProperties">      
  6.             <props>      
  7.                 <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop>      
  8.                 <prop key="connection.provider_class">      
  9.                     org.hibernate.connection.C3P0ConnectionProvider      
  10.                 </prop>      
  11.                 <prop key="hibernate.show_sql">true</prop>      
  12.                 <prop key="hibernate.cache.use_query_cache">true</prop>      
  13.                 <prop key="hibernate.cache.provider_class">      
  14.                     org.hibernate.cache.EhCacheProvider      
  15.                 </prop>      
  16.                 <prop key="hibernate.jdbc.batch_size">0</prop>      
  17.             </props>      
  18.         </property>    
<bean id="oracleSessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">   
        <property name="dataSource">   
            <ref bean="oracleDataSource"/>   
        </property>   
        <property name="hibernateProperties">   
            <props>   
                <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop>   
                <prop key="connection.provider_class">   
                    org.hibernate.connection.C3P0ConnectionProvider   
                </prop>   
                <prop key="hibernate.show_sql">true</prop>   
                <prop key="hibernate.cache.use_query_cache">true</prop>   
                <prop key="hibernate.cache.provider_class">   
                    org.hibernate.cache.EhCacheProvider   
                </prop>   
                <prop key="hibernate.jdbc.batch_size">0</prop>   
            </props>   
        </property>  


     以上引用出处:http://hsyd.iteye.com/blog/320579
     我添加后,又出现了新的问题:
      org.springframework.transaction.TransactionSystemException: Could not roll back Hibernate transaction; nested exception is org.hibernate.TransactionException: JDBC rollback failed
     很是郁闷,网上查了很多,大多都是在说要先save一个空值,然后update,我试了一下,总感觉在ssh架构中,不太好实现,所以都未能解决问题,估计我的功力还不够,呵呵,但我在网上看到说:
    

引用
用oracle10G带的jdbcdriver,clob可以直接读写了


     所以我就想如果我用oracle10G带的jdbcdriver,是不是也能够直接读写blob类型的呢?我试了一下,欣喜若狂。。。,终于解决了,现分享给为此困惑的同行。
      顺便说明一下,我以前用的oracle驱动是class12.jar,我从网上下了10g的驱动,名称为:ojdbc14.jar,现作为附件供大家方便下载。

原文::http://jiangpan.iteye.com/blog/422449

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值