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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值