分享

【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;

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多