MySql、Oracle和达梦统计记录数和占用内存

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没找到相似的表,找到的朋友可以评论留下。

猜你喜欢

转载自blog.csdn.net/qq845484236/article/details/108409523