您当前的位置:首页 > 电脑百科 > 数据库 > Oracle

一文看懂Oracle查询表空间的每日增长量和历史情况统计

时间:2019-10-14 11:48:53  来源:  作者:

概述

今天主要总结一下Oracle表空间每日增长和历史情况统计的一些脚本,仅供参考。


11g统计表空间的每日增长量

SELECT a.snap_id,
 c.tablespace_name ts_name,
 to_char(to_date(a.rtime, 'mm/dd/yyyy hh24:mi:ss'),
 'yyyy-mm-dd hh24:mi') rtime,
 round(a.tablespace_size * c.block_size / 1024 / 1024, 2) ts_size_mb,
 round(a.tablespace_usedsize * c.block_size / 1024 / 1024, 2) ts_used_mb,
 round((a.tablespace_size - a.tablespace_usedsize) * c.block_size / 1024 / 1024,
 2) ts_free_mb,
 round(a.tablespace_usedsize / a.tablespace_size * 100, 2) pct_used
 FROM dba_hist_tbspc_space_usage a,
 (SELECT tablespace_id,
 substr(rtime, 1, 10) rtime,
 max(snap_id) snap_id
 FROM dba_hist_tbspc_space_usage nb
 group by tablespace_id, substr(rtime, 1, 10)) b,
 dba_tablespaces c,
 v$tablespace d
 where a.snap_id = b.snap_id
 and a.tablespace_id = b.tablespace_id
 and a.tablespace_id = d.TS#
 and d.NAME = c.tablespace_name
 and to_date(a.rtime, 'mm/dd/yyyy hh24:mi:ss') >= sysdate - 30
 order by a.tablespace_id, to_date(a.rtime, 'mm/dd/yyyy hh24:mi:ss') desc;
一文看懂Oracle查询表空间的每日增长量和历史情况统计

 


12c统计表空间的每日增长量

SELECT a.snap_id,
 a.con_id,
 e.name pdbname,
 c.tablespace_name ts_name,
 to_char(to_date(a.rtime, 'mm/dd/yyyy hh24:mi:ss'), 'yyyy-mm-dd hh24:mi') rtime,
 round(a.tablespace_size * c.block_size / 1024 / 1024, 2) ts_size_mb,
 round(a.tablespace_usedsize * c.block_size / 1024 / 1024, 2) ts_used_mb,
 round((a.tablespace_size - a.tablespace_usedsize) * c.block_size / 1024 / 1024,
 2) ts_free_mb,
 round(a.tablespace_usedsize / a.tablespace_size * 100, 2) pct_used
 FROM cdb_hist_tbspc_space_usage a, 
 (SELECT tablespace_id,
 nb.con_id,
 substr(rtime, 1, 10) rtime,
 max(snap_id) snap_id
 FROM dba_hist_tbspc_space_usage nb
 group by tablespace_id, nb.con_id,substr(rtime, 1, 10)) b,
 cdb_tablespaces c,
 v$tablespace d,
 V$CONTAINERS e
 where a.snap_id = b.snap_id
 and a.tablespace_id = b.tablespace_id
 and a.con_id=b.con_id
 and a.con_id=c.con_id
 and a.con_id=d.con_id
 and a.con_id=e.con_id
 and a.tablespace_id=d.TS#
 and d.NAME=c.tablespace_name
 and to_date(a.rtime, 'mm/dd/yyyy hh24:mi:ss') >=sysdate-30
 order by a.CON_ID,a.tablespace_id,to_date(a.rtime, 'mm/dd/yyyy hh24:mi:ss') desc;

估算oracle 数据库,数据库对象历史增长情况

--最近七天数据库的增长情况,这个只是一个估算值。
select sum(space_used_total) / 1024 / 1024 / 1024 "last 7 days db increase - G"
 from dba_hist_seg_stat s, dba_hist_seg_stat_obj o, dba_hist_snapshot sn
 where s.obj# = o.obj#
 and sn.snap_id = s.snap_id
 and begin_interval_time > sysdate - 8
 order by begin_interval_time
一文看懂Oracle查询表空间的每日增长量和历史情况统计

 


查看数据库历史增长情况

此处是通过计算数据库所有表空间的历史增长情况来计算数据库历史情况。

--不含undo和temp
with tmp as (
select rtime,sum(tablespace_usedsize_kb) tablespace_usedsize_kb, sum(tablespace_size_kb) tablespace_size_kb 
from (select rtime, e.tablespace_id, (e.tablespace_usedsize)*(f.block_size)/1024 tablespace_usedsize_kb, 
(e.tablespace_size)*(f.block_size)/1024 tablespace_size_kb from dba_hist_tbspc_space_usage e, dba_tablespaces f, v$tablespace g
 where e.tablespace_id = g.TS# and f.tablespace_name = g.NAME and f.contents not in ('TEMPORARY','UNDO')) group by rtime) 
select tmp.rtime, tablespace_usedsize_kb, tablespace_size_kb,(tablespace_usedsize_kb - LAG(tablespace_usedsize_kb, 1, NULL)
 OVER(ORDER BY tmp.rtime)) AS DIFF_KB from tmp, (select max(rtime) rtime from tmp group by substr(rtime, 1, 10)) t2
 where t2.rtime = tmp.rtime;
​
--含undo和temp
with tmp as (
select min(rtime) rtime, sum(tablespace_usedsize_kb) tablespace_usedsize_kb, sum(tablespace_size_kb) tablespace_size_kb 
from (select rtime, e.tablespace_id, (e.tablespace_usedsize) * (f.block_size) / 1024 tablespace_usedsize_kb, 
(e.tablespace_size) * (f.block_size) / 1024 tablespace_size_kb from dba_hist_tbspc_space_usage e, dba_tablespaces f, v$tablespace g 
where e.tablespace_id = g.TS# and f.tablespace_name = g.NAME) group by rtime) 
select tmp.rtime, tablespace_usedsize_kb, tablespace_size_kb, (tablespace_usedsize_kb-LAG(tablespace_usedsize_kb, 1, NULL)
OVER(ORDER BY tmp.rtime)) AS DIFF_KB from tmp, (select min(rtime) rtime from tmp group by substr(rtime, 1, 10)) t2 
where t2.rtime = tmp.rtime
一文看懂Oracle查询表空间的每日增长量和历史情况统计

 


一文看懂Oracle查询表空间的每日增长量和历史情况统计

 


列出相关段对象在 快照时间内的使用空间的历史变化信息

select obj.owner,
 obj.object_name,
 to_char(sn.BEGIN_INTERVAL_TIME, 'RRRR-MON-DD') start_day,
 sum(a.db_block_changes_delta) block_increase
 from dba_hist_seg_stat a, dba_hist_snapshot sn, dba_objects obj
 where sn.snap_id = a.snap_id
 and obj.object_id = a.obj#
 and obj.owner not in ('SYS', 'SYSTEM')
 and end_interval_time between to_timestamp('01-OCT-2019', 'DD-MON-RRRR') and
 to_timestamp('09-OCT-2019', 'DD-MON-RRRR')
 group by obj.owner,
 obj.object_name,
 to_char(sn.BEGIN_INTERVAL_TIME, 'RRRR-MON-DD')
 order by obj.owner, obj.object_name;
一文看懂Oracle查询表空间的每日增长量和历史情况统计


Tags:Oracle 查询表   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
概述今天主要总结一下Oracle表空间每日增长和历史情况统计的一些脚本,仅供参考。11g统计表空间的每日增长量SELECT a.snap_id, c.tablespace_name ts_name, to_char(to_date(...【详细内容】
2019-10-14  Tags: Oracle 查询表  点击:(522)  评论:(0)  加入收藏
▌简易百科推荐
安装环境Linux服务器:Centos 6 64位Oracle服务器:Oracle11gR2 64位 系统要求说明:内存必须高于1G的物理内存;交换空间,一般为内存的2倍(1G的内存可以设置swap 分区为3G大小);硬...【详细内容】
2021-12-27  守护梦想2022    Tags:Oracle   点击:(2)  评论:(0)  加入收藏
1、 登陆CentOS 2、 查看备份脚本,脚本放在\usr\local目录下 3、 编写数据库备份脚本,内容如下 前提是需要在Oracle创建directory文件,如果没有,可以create创建并授权给相应的用...【详细内容】
2021-12-10  JasonTang    Tags:Oracle   点击:(14)  评论:(0)  加入收藏
之前写了个Oracle12c在Redhat6.8下的静默安装,操作系统版本太老了而且没配插图,今天重新写个centos 7 下静默安装。 准备环境:centos 7 虚拟机一台,Oracle12c安装包。1、检查防...【详细内容】
2021-10-12  it运维小土豆  今日头条  Tags:Oracle   点击:(29)  评论:(0)  加入收藏
JDK 17 正式发布+免费牛逼啊,JDK 16 刚发布半年(2021/03/16),JDK 17 又如期而至(2021/09/14),这个时间点牛逼啊,蹭苹果发布会的热度?记得当年 JDK 15 的发布也是同天,巧了。。虽然 iPho...【详细内容】
2021-09-16  Java技术栈  掘金  Tags:Oracle   点击:(88)  评论:(0)  加入收藏
Oracle日志文件是Oracle数据库存储信息的重要文件,主要用来存储数据库变化的操作信息。Oracle日志文件可以分为两种:重做日志文件(redo log file)、归档日志文件,其中重做日志文...【详细内容】
2021-08-19  free教程    Tags:Oracle日志   点击:(101)  评论:(0)  加入收藏
本例子在真实环境应用过,获得了很好的体验,特将其分享出来供各位朋友使用。后续我会持续把相关的知识一点一点的更新,请各位多多关注,多多支持。测试速度:导出速度大概800M/s,如...【详细内容】
2021-08-17  大树唛包    Tags:oracle   点击:(88)  评论:(0)  加入收藏
天冒险重启下Oracle rac,分三个步骤,停实例---停集群---重启服务器。 1、关闭实例检查状态su - gridcrsctl status res -t 注意:只在一个节点执行就行,或者为了保险期间,使用shut...【详细内容】
2021-07-16  死磕IT    Tags:Oracle rac   点击:(128)  评论:(0)  加入收藏
两个字符串相似度的比较:SYS.UTL_MATCH.edit_distance_similarity用法:select SYS.UTL_MATCH.edit_distance_similarity('河北沧州东塑股份有限公司','河北沧州东...【详细内容】
2021-07-07  Onceagain75783189    Tags:比较函数   点击:(112)  评论:(0)  加入收藏
现在有一个用户A,想把这个用户A下面的所有的表查询权限都赋予用户X,该怎么做?同样的问题,如果有4个用户A、B、C、D,需要把这4个用户下面所有的表的只读权限赋予用户X、Y、Z三个用...【详细内容】
2021-06-23  程序猿集锦    Tags:Oracle   点击:(103)  评论:(0)  加入收藏
oarcle数据库真正存放数据的是数据文件(data files),Oarcle表空间(tablespaces)实际上是一个逻辑的概念,他在物理上是并不存在的,那么把一组data files 捻在一起就成为一个表空间。...【详细内容】
2021-04-27  SQL小帅哥  今日头条  Tags:Oracle   点击:(200)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条