关于DELPHI使用ORACLE回滚段的问题(急)

本文探讨了在使用DELPHI程序处理大量数据时遇到的ORACLE回滚段问题,包括快照过旧错误、指定回滚段的最佳实践、减少commit次数的影响,以及如何优化25万条数据的处理流程。
关于DELPHI使用ORACLE回滚段的问题(急) Delphi / Windows SDK/API
http://www.delphi2007.net/DelphiDB/html/delphi_20061220125734202.html
我写了一个DELPHI程序,程序中没有起事物,只是作了一个循环,大概25万条.  
  每条取出一个NO.传到一个ORACLE的PROCEDURE中.  
  这个过程包括三个表的插入,一个表的更新。  
  1、执行十几万的时候报错   ORA-01555   快照过旧  
        问:我觉的它应该是一条一提交啊,不存在使用回滚段问题。  
  2、我试着使用指定回滚段。  
        问:应该在事物前还是在事物后?  
  3、在事务的TRY中:  
        if   i   =   10000   then  
        begin  
            database1.commit;  
            query1.ExecSQL;  
        end;  
        query,内容如下  
        “set   transaction   use   rollback   segment   RBS2”  
        这么转回滚段对么?  
  4、查询打开后滚动占回滚段吗?  
  5、我打开的表,在过程中也更新它,有影响吗?  
  6、执行这25万条最好的办法是什么,有什么注意事项吗?

求助,各位大哥,帮帮我吧,本来程序是分段执行的,可用户非要一个按钮搞定.  
  我都快郁闷死了

事务

数据量较大,第一考虑使用事务!如果事务过大,就需要调整回滚段的大小,建议建立若干个小回滚段和几个大的回滚段以应付较大事务。

关注!

oracle   的解决方法:  
  回滚段太小,可以增加一个大的回滚段试一试520745598  
   
  主要是由于回滚段太小,可以为此事务指定一个大的回滚段,利用Set   Transaction   use   rollback   segment   seg_name   语句.如果数据库中没有较大的回滚段,那么应该新增一个,然后使它Online,再指定它.  
   
 

减少一次commit的量,应该也有好处,如:  
      if   i   =   10000   then  
        begin  
            database1.commit;  
   
  10000   改为   5000

转载于:https://www.cnblogs.com/delphi2007/archive/2009/02/19/1394102.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值