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 统计用户下表的数据量实现脚本,大家如有疑问可以留言,或者联系站长。感谢亲们支持!!!
我想要获取技术服务或软件
服务范围:MySQL、ORACLE、SQLSERVER、MongoDB、PostgreSQL 、程序问题
服务方式:远程服务、电话支持、现场服务,沟通指定方式服务
技术标签:数据恢复、安装配置、数据迁移、集群容灾、异常处理、其它问题
本站部分文章参考或来源于网络,如有侵权请联系站长。
数据库远程运维 Oracle 统计用户下表的数据量实现脚本
相关文章
- 探索Oracle 中文官网之旅(oracle中文官网)
- 连接Oracle数据库连接:实现高效数据访问(oracle数据库数据源)
- Oracle表连接:实现数据更有效的共享(oracle的表连接)
- Oracle触发器的多种类型及其应用(oracle触发器类型)
- Oracle数据库中轻松实现内容换行(oracle 内容换行)
- 步趋向成功Oracle公司走入成功的步伐(oracle公司举步维艰)
- Oracle优化降低占用空间(oracle减少占用空间)
- Oracle实现进程写入的可靠性探究(oracle 写进程)
- DB2切换到Oracle一次实现升级复制(db2的复制oracle)
- 微观世界中的Oracle成就万物(micro和oracle)
- Oracle JRE实现完美的运行环境(jre oracle)
- 构建MySQL与Oracle平台之间数据倒入的IMP方法(imp 倒入oracle)
- Oracle中用For循环遍历数组的实现方式(oracle中遍历数组)
- Oracle数据库中使用正则表达式匹配的实现(oracle中的正则匹配)
- Oracle如何给不够位数的数值补上零(oracle位数不够补零)
- 以Oracle 乐观锁实现数据库并发控制(oracle乐观锁实例)
- Oracle中父子树数据结构的实现(oracle中父子树)
- Oracle数据库中实现模糊查询的技巧(oracle中模糊查找)
- Oracle 数据库中文字段排序解决方法(oracle中文字段排序)
- 排序Oracle中多列实现降序排序的方法(oracle中多个降序)
- Oracle事务可实现多个事务同时开启(oracle事务开启多个)
- 行在Oracle中实现列信息的横向转换(oracle中列转横)
- Oracle中实现分页查询的有效方法(oracle中分页的用法)
- Oracle无法更新视图问题与解决方案(oracle不能更新视图)
- Oracle数据库在Mac系统上的破解技术(oracle mac破解)