360图书馆文章备份

← 返回首页

【oracle】查看当前用户各个表的记录数

2019-05-21
 https://blog.csdn.net/debimeng/article/details/86261513


因没有dba权限,当前用户下查看全部表名,只能通过user_tables视图访问。

方法一:(直接访问user_tables)
select t.table_name,t.num_rows from user_tables t;

但有一个问题,有可能查看num_rows字段没有数据,因其统计信息不完整。

方法二:(存储过程)

  1. create or replace procedure tj_cuser_tablenums is
  2. --变量
  3. v_tablename varchar2(100);
  4. v_sql varchar2(200);
  5. v_count int;
  6. --获取当前数据库中的所有表的表名
  7. cursor table_loop is select table_name from user_tables;
  8. begin
  9. --打开游标
  10. open table_loop;
  11. loop
  12. fetch table_loop into v_tablename;
  13. --如获取不到表名或已获取完就退出循环
  14. exit when table_loop %notfound;
  15. v_sql :='select count(1) from ' || v_tablename;
  16. --执行sql语句
  17. execute immediate v_sql into v_count;
  18. --输出
  19. dbms_output.put_line(v_tablename || ':' v_count);
  20. end loop;
  21. close table_loop;
  22. end tj_cuser_tablenums;