文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何编写Oracle查询表空间的每日增长量和历史情况统计的脚本

2024-04-02 19:55

关注

如何编写Oracle查询表空间的每日增长量和历史情况统计的脚本,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

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

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

SELECT a.snap_id,  c.tablespace_name ts_name,  to_char(to_date(a.rtime, 'mm/dd/yyyy hh34:mi:ss'),  'yyyy-mm-dd hh34: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 hh34:mi:ss') >= sysdate - 30  order by a.tablespace_id, to_date(a.rtime, 'mm/dd/yyyy hh34: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 hh34:mi:ss'), 'yyyy-mm-dd hh34: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 hh34:mi:ss') >=sysdate-30  order by a.CON_ID,a.tablespace_id,to_date(a.rtime, 'mm/dd/yyyy hh34: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 ssn.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查询表空间的每日增长量和历史情况统计的脚本

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯