【TechTarget中国原创】问:我们在和产品数据库同步的测试数据库中执行包。我们执行的这个包有多个程序,在产品数据库中执行这个包需要六个小时。但是在测试数据库中执行其中一个程序时出现了故障,并且报错ORA-12801:error signaled in parallel query server P005:
ORA-01555: snapshot too old: rollback segment number 1 with name "_SYSSMU1$" too small
在测试数据库中和在产品数据库中的程序是一样的,但是我们仍然收到了错误信息。目前我们查不出原因,因为在同样的程序在产品数据库中运行得很好。你能说明是什么原因吗?
答:ORA-1555错误表明你的UNDO表空间太小或者UNDO_RETENTION字段设置的空间不足。或者两种情况都有可能。如果这个包要六个小时才能执行,UNDO_RETENTION字段至少要设为21600 (21600秒=6小时)。你需要足够大的UNDO表空间装这么大的undo信息。