ORACLE 统计查看每一个表的行数

create or replace procedure sp_static_tab

/**
   * 统计所有表的行数
   */
is
 vv_table_name varchar2(64); 
 vi_table_rows number;
 vv_sqlstr     varchar2(200);
 
 cursor r_cursor is
 select table_name from user_tables
  where substr(table_name,1,3)<>‘BIN‘; 
 
begin
 EXECUTE IMMEDIATE ‘truncate table tb_static_tab‘;
   
  OPEN r_cursor;
 LOOP 
  FETCH r_cursor INTO vv_table_name;
  exit when r_cursor %notfound;
  vv_sqlstr:=‘select count(1) from ‘|| vv_table_name;
  
  begin     
   EXECUTE IMMEDIATE vv_sqlstr
      into vi_table_rows;
     
   insert into tb_static_tab
   (
    static_date ,
    table_name  ,
    table_rows  ,
    table_size
   )
   values(
    sysdate,
    vv_table_name,
    vi_table_rows,
    null
   );
  end;
   
 end loop;
  close r_cursor;  
  commit;
    
end;

/****************************************
--建表
create table tb_static_tab
(
 static_date date    , -- 统计日期
 table_name varchar2(64),  -- 表名
 table_rows number,       -- 表行数
 table_size number         -- 表占空间 byte
);
*****************************************/

原文地址:https://www.cnblogs.com/cx6872/p/8509553.html

时间: 2024-08-26 21:30:25

ORACLE 统计查看每一个表的行数的相关文章

7.04 求一个表的行数

问题:计算一个表的行数,或计算某个列中值的个数.例如,找到职员总数以及每个部门的职员数.解决方案:如果以整个表作为一个组或一个窗口计算行数,则只需使用COUNT函数及"*"字符:select count(*) from emp; 如果要创建多个数据组或窗口,则使用COUNT函数的同时,还要使用GROUP BY子句:select deptno,count(*) from emp group by deptno;

如何查看数据库内表记录行数及表大小

create table #Data(name varchar(100),row varchar(100),reserved varchar(100),data varchar(100),index_size varchar(100),unused varchar(100))  declare @name varchar(100) declare cur cursor  for     select name from sysobjects where xtype='u' order by na

oracle 统计指定条件下所有表的行数

今天 需要统计下指定用户下的所有表的行数,于是采用了oracle 内置视图: select table_name,num_rows  from dba_tables where owner = 'USERNAME';  或 select table_name,num_rows from user_all_tables ; 可是统计结果发现,有的表的统计数量和实际数量有差异,因此,直接自己写了个统计指定条件下表的记录的sql: --创建一个表用于存储计算结果 create table t_temp

Oracle统计用户所有表的行数

DECLARE   CURSOR c1 is select table_name from user_tables;   V_TABLE_NAME user_tables.TABLE_NAME%TYPE;   V_CNT number;   V_SQL varchar2(2000); BEGIN   FOR V_TABLE_NAME in c1 loop      V_SQL := 'select count(1) from ' || V_TABLE_NAME.table_name;      

SqlSever基础 count 查询一个表有多少行

镇场诗:---大梦谁觉,水月中建博客.百千磨难,才知世事无常.---今持佛语,技术无量愿学.愿尽所学,铸一良心博客.------------------------------------------ 1 table 2 code 1 --创建一个数据库 2 create database helloworld1 3 4 use master 5 drop database helloworld1 6 7 --用helloworld1这个数据库 8 use helloworld1 9 10 --

c语言:实现一个函数,打印乘法口诀表,口诀表的行数和列数自己指定

实现一个函数,打印乘法口诀表,口诀表的行数和列数自己指定, 输入9,输出9*9口诀表,输出12,输出12*12的乘法口诀表. 程序: #include<stdio.h> void mul(int n)//multiplication 乘法 { int i, j; for (i = 1; i <= n; i++) { for (j = 1; j <= i; j++) { printf("%d*%d=%-2d  ", i, j, i*j); //其中%2d中的2表示

【SQL】统计所有表的行数

原文:[SQL]统计所有表的行数 环境:mssql ent 2k8 r2 原理:遍历所有用户表,用sp_spaceused过程分别获取每张表的行数并写入临时表,最后返回临时表 IF OBJECT_ID('tempdb..#TableRowCount','U') IS NOT NULL DROP TABLE #TableRowCount GO CREATE TABLE #TableRowCount (Name sysname PRIMARY KEY, RowCnt DECIMAL(11,0), R

mysql查看数据库中所有表的行数,并进行排序

mysql查看数据库中所有表的行数,并进行排序: 进行数据库迁移或还原后,可以通过比较行数,检查数据是否正确. mysql> use information_schema; mysql> select table_name,table_rows from tables where TABLE_SCHEMA= 'kpsumi' order by table_rows desc; 原文地址:http://blog.51cto.com/9285090/2119096

查看SqlAzure和SQLServer中的每个表数据行数

SqlAzure中的方式: select t.name ,s.row_count from sys.tables t join sys.dm_db_partition_stats s ON t.object_id = s.object_id and t.type_desc = 'USER_TABLE' and t.name not like '%dss%' and s.index_id = 1 order by row_count desc SQLServer的方式: select a.name