问题描述
一个客户碰到的具体需求,分区表中有些分区所在的表空间被OFFLINE,导致在删除统计信息时报错。
下面通过例子来说明这个问题:
SQL> CREATE TABLE t_part_read (id NUMBER) 2 partition BY range (id) 3 (partition p1 VALUES less than (10) tablespace ts1, 4 partition p2 VALUES less than (20) tablespace ts2, 5 partition pmax VALUES less than (maxvalue) tablespace users); TABLE created. SQL> INSERT INTO t_part_read SELECT rownum FROM tab; 54 ROWS created. SQL> commit; Commit complete. SQL> EXEC dbms_stats.gather_table_stats(USER, 'T_PART_READ') PL/SQL PROCEDURE successfully completed. SQL> ALTER tablespace ts1 READ ONLY; Tablespace altered. SQL> EXEC dbms_stats.gather_table_stats(USER, 'T_PART_READ') PL/SQL PROCEDURE successfully completed. SQL> ALTER tablespace ts1 offline; Tablespace altered. SQL> EXEC dbms_stats.gather_table_stats(USER, 'T_PART_READ') BEGIN dbms_stats.gather_table_stats(USER, 'T_PART_READ'); END; * ERROR at line 1: ORA-00376: file 6 cannot be READ at this TIME ORA-01110: DATA file 6: '/u01/app/oracle/oradata/ORCL/datafile/o1_mf_ts1_7w8l5fz1_.dbf' ORA-06512: at "SYS.DBMS_STATS", line 23829 ORA-06512: at "SYS.DBMS_STATS", line 23880 ORA-06512: at line 1
专家解答
如果将表空间只读,并不会影响到表空间上的表或分区的统计信息的收集,因为收集过程只是读取,而收集的结果信息是写到SYSTEM表空间的。
但是如果分区所在的表空间处于OFFLINE状态,那么在统计信息收集的过程中就会报错。
有一个很简单的方法可以解决这个问题,就是将被OFFLINE影响的分区的统计信息锁定,这样Oracle在收集统计信息时就会跳过锁定的分区,通过这个办法就可以避免统计信息收集过程中的报错:
SQL> EXEC dbms_stats.lock_partition_stats(USER, 'T_PART_READ', 'P1') PL/SQL PROCEDURE successfully completed. SQL> EXEC dbms_stats.gather_table_stats(USER, 'T_PART_READ') BEGIN dbms_stats.gather_table_stats(USER, 'T_PART_READ'); END; * ERROR at line 1: ORA-00376: file 6 cannot be READ at this TIME ORA-01110: DATA file 6: '/u01/app/oracle/oradata/ORCL/datafile/o1_mf_ts1_7w8l5fz1_.dbf' ORA-06512: at "SYS.DBMS_STATS", line 23829 ORA-06512: at "SYS.DBMS_STATS", line 23880 ORA-06512: at line 1 SQL> EXEC dbms_stats.gather_table_stats(USER, 'T_PART_READ', granularity => 'PARTITION') PL/SQL PROCEDURE successfully completed.
即使锁定分区后,尝试收集统计信息仍然报错,这是因为Oracle默认除了要收集分区上的统计信息以外,还要收集表级的统计信息,而这就会造成被OFFLINE影响的分区也要被读取。
解决方法就是在收集统计信息的时候指定收集的粒度是分区,不收集表上的GLOBAL信息。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。