我写了一个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万条最好的办法是什么,有什么注意事项吗?
每条取出一个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万条最好的办法是什么,有什么注意事项吗?
回滚段太小,可以增加一个大的回滚段试一试520745598主要是由于回滚段太小,可以为此事务指定一个大的回滚段,利用Set Transaction use rollback segment seg_name 语句.如果数据库中没有较大的回滚段,那么应该新增一个,然后使它Online,再指定它.
if i = 10000 then
begin
database1.commit;10000 改为 5000