COL_USAGE$被用来记录数据库的列级使用信息,这些信息被用来辅助统计信息收集。
比如在上一个测试中,当我们在OWNER字段执行了一定的查询,此后这个信息被记录在COL_USAGE$中。如果再次使用缺省选项收集统计数据,该字段的柱状图仍然会被收集。
当手工删除列的信息记录后,统计信息不会再被收集:
接下来再对表进行统计信息收集,则列的直方图不会被收集:
在10g里,有很多Bug和col_usage$有关,该表的存储空间可能耗用很高,需要注意监控。
比如在上一个测试中,当我们在OWNER字段执行了一定的查询,此后这个信息被记录在COL_USAGE$中。如果再次使用缺省选项收集统计数据,该字段的柱状图仍然会被收集。
当手工删除列的信息记录后,统计信息不会再被收集:
SQL> select object_id from dba_objects where object_name='EYGLE';
OBJECT_ID
----------
12918
SQL> delete from col_usage$ where obj#=12918;
1 row deleted.
SQL> commit;
Commit complete.
接下来再对表进行统计信息收集,则列的直方图不会被收集:
SQL> exec dbms_stats.gather_table_stats(user,'EYGLE');
PL/SQL procedure successfully completed
SQL> select count(*) from dba_tab_histograms where table_name='EYGLE';
COUNT(*)
----------
26
在10g里,有很多Bug和col_usage$有关,该表的存储空间可能耗用很高,需要注意监控。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




