主页 > 知识库 > Oracle 统计用户下表的数据量实现脚本

Oracle 统计用户下表的数据量实现脚本

热门标签:电话机器人那种好 地图标注的坐标点 上海网络外呼系统 区域地图标注怎么设置 外呼系统好点子 南通电销外呼系统哪家强 理财产品电销机器人 百度地图标注饭店位置怎么 百度地图标注注解

要想统计用户下所有表的数据量,可以查看user_tables,此表里面是统计信息,当然这个可能不太准,要想非常精确,需要直接count表。下面的脚本有异常不中断,可以重复执行的特点。

create table bk_count_tables
(
 owner VARCHAR2(30),
 table_name VARCHAR2(30),
 part_col varchar2(100),--分区字段
 row_s number,
 gather_time date
);
create index ind_bct_own_table on bk_count_tables(owner,table_name);
set serveroutput on
declare
cursor c_cursor is select s.OWNER, s.TABLE_NAME, col.column_name part_col
  from dba_tables s,
    (select owner,
        name,
        listagg(column_name, ',') within group(order by null) column_name
      from (select owner, name, column_name
          from dba_part_key_columns
         where owner in ('TEST')
          and object_type = 'TABLE'
          and name not like 'BIN$%'
         union all
         select owner, name, column_name
          from dba_subpart_key_columns
         where owner in ('TEST')
          and object_type = 'TABLE'
          and name not like 'BIN$%')
     group by owner, name) col
 where s.OWNER in ('TEST')
  and not regexp_like(table_name, '[0-9]{3,8}')
  and s.table_name not like '%BAK%'
  and s.table_name not like '%A2K%'
  and s.table_name not like 'BK%'
  and s.table_name not like 'BIN%'
  and s.OWNER = col.owner(+)
  and s.TABLE_NAME = col.name(+)
order by s.TABLE_NAME ;
c_row c_cursor%rowtype;
t_rows number;
begin
 for c_row in c_cursor loop
  begin
   execute immediate 'select count(*) from bk_count_tables where owner=:1 and TABLE_NAME=:2 and rownum=1' 
   into t_rows using c_row.OWNER,c_row.TABLE_NAME ;
   if(t_rows = 0) then 
    execute immediate 'select count(*) from "'||c_row.TABLE_NAME||'"' into t_rows;
    insert into bk_count_tables values(c_row.OWNER,c_row.TABLE_NAME,c_row.part_col,t_rows,sysdate);
    commit; 
    end if;
  EXCEPTION
   WHEN OTHERS THEN
   DBMS_OUTPUT.PUT_LINE(c_row.OWNER||'---'||c_row.TABLE_NAME);
   rollback; 
  end;
 end loop;
end;
/

总结

以上所述是小编给大家介绍的Oracle 统计用户下表的数据量实现脚本,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:
  • PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法
  • Oracle 12c新特性之如何检测有用的多列统计信息详解
  • Oracle 11g收集多列统计信息详解
  • Oracle Translate 统计字符出现的次数示例代码
  • Oracle数据库按时间进行分组统计数据的方法
  • oracle表空间中空表统计方法示例介绍
  • oracle数据库下统计专营店的男女数量的语句

标签:中卫 昭通 宁波 绍兴 百色 自贡 辽源 海东

巨人网络通讯声明:本文标题《Oracle 统计用户下表的数据量实现脚本》,本文关键词  Oracle,统计,用户,下表,的,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Oracle 统计用户下表的数据量实现脚本》相关的同类信息!
  • 本页收集关于Oracle 统计用户下表的数据量实现脚本的相关信息资讯供网民参考!
  • 推荐文章