首先建立一个计算函数
create or replace function count_rows(table_name in varchar2,
owner in varchar2 default null)
return number authid current_user IS
num_rows number;
stmt varchar2(2000);
begin
if owner is null then
stmt := 'select count(*) from "' || table_name || '"';
else
stmt := 'select count(*) from "' || owner || '"."' || table_name || '"';
end if;
execute immediate stmt
into num_rows;
return num_rows;
end;
然后通过计算函数进行统计所有表的表名+记录数
select table_name, count_rows(table_name) nrows from user_tables
查询表的注释
select table_name, count_rows(table_name) nrows from user_tables
连接两个表得到所有表的表名+注释+记录数
select a.table_name, count_rows(a.table_name) ,b.comments from user_tables a left join (select * from user_tab_comments) b on a.TABLE_NAME=b.table_name