ORACLE一致读与ORA-01555 code
用户user1对表进行了更新操做,用户user2在user1尚未进行提交前读表中数据,并且是大批量的读取(打个比方:耗时3分钟)而在这3分钟内user1进行了提交操做,那又会产生什么影响呢?这个时候怎么保证读写一致性呢?这个时候DBMS就要保证有足够大的undo表空间来存放修改前的数值,,以保证user2读取的数据是修改前的一致数据.而后下次再读取时候就是更新后的数据了. ora-01555快照过旧就是由于undo空间不够大,其中一部分undo数据被覆盖了,用户没法得到修改前的数据。 undo数据分为三种: 活动的undo:未提交事务的undo数据,这些undo数据永远不能覆盖,用于回滚rollback事务。 过时的undo:已提交事务的undo数据,这些undo数据能够覆盖。 未过时的undo:事务已提交,但事务提交前,有些查询正在进行,它要读取的是提交前的数据,这部分数据就是未过时数据。若是这部分undo数据被覆盖了,就会发生ora-01555错误。 一个解决方法是,指定undo表空间参数UNDO_TABLESPACE,并将undo空间管理方法设置成自动扩展:UNDO_MANAGEMENT=AUTO。 这种方法可能产生的结果是: 由于undo表空间装了太多未过时(unexpired)的undo数据,新的transaction没法向其中写入undo数据,这时transaction就会发生ORA-30036错误。