MySql、Oracle和达梦统计记录数和占用内存
项目业务需要,然后baidu了两三个小时、实践、整理了以下可行的方案如下:
MySql
1、设置更新时间间隔,刷新系统表
SET session information_schema_stats_expiry=0;
SET @@session.information_schema_stats_expiry=0;
这里设置的是session级别,不影响global的设置。
查看修改的值:
SHOW session VARIABLES LIKE 'information_schema_stats_expiry';
2、查询
select TABLE_SCHEMA, TABLE_NAME,CONCAT(round(DATA_LENGTH/1024/1024,2) ,'MB')as TABLE_VOLUME,TABLE_ROWS
from information_schema.tables
where TABLE_TYPE='BASE TABLE' and TABLE_SCHEMA = 'mySchema'
-- BASE TABLE是为了区分视图和表
Oracle
1、查询
select t.owner TABLE_SCHEMA,TABLE_NAME, num_rows||’’ TABLE_ROWS, to_char(round(s.BYTES /1024/1024.0,2),‘fm99999999990.00’) TABLE_VOLUME
from dba_tables t
left join dba_segments s on t.table_name=s.segment_name
where s.segment_type like ‘TABLE%’
and t.owner = ‘MySchema’
达梦数据库
1、刷新系统表
DBMS_STATS.GATHER_SCHEMA_STATS(‘mySchema’,100,TRUE,‘FOR ALL TABLE NUM_ROWS AUTO’);
中间的参数有几篇博客写的很详细,有兴趣可以看看:
https://www.cnblogs.com/Zeros/p/7026174.html
2、查询
select t.owner TABLE_SCHEMA,TABLE_NAME, num_rows||'' TABLE_ROWS,
to_char(round(s.BYTES /1024/1024.0,2),'fm99999999990.00') TABLE_VOLUME
from dba_tables t
left join dba_segments s on t.table_name=s.segment_name
where s.segment_type like 'TABLE%' AND t.tablespace_name = 'QMUSER'
dba级别的都是需要超级用户权限的,企业中一般不开放给应用使用,故此dba_tables可以用all_tables代替,但是dba_segments没找到相似的表,找到的朋友可以评论留下。