日期:2014-05-16  浏览次数:20616 次

Oracle 查询某一用户下所有表的记录数

要查询Oracle下某一个用户下所有表的记录条数,可以采用如下办法:

1、创建function count_tables_rows

create or replace function count_table_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;

2、使用sql语句查询

select table_name, count_table_rows(table_name) nrows

? from user_tables

?order by nrows desc

通过以上两个步骤,即可查询出某一用户下所有表的记录数据集合。