批量占满TEMP表空间问题处理与排查
创始人
2024-05-24 00:48:37
0

批量占满TEMP表空间问题处理与排查

  • 应急处置
  • 问题排查
    • 查看占用TEMP表空间高的SQL
    • 获取目标SQL执行计划
      • 方法一:EXPLAIN PLAN FOR
      • 方法二:DBMS_XPLAN.DISPLAY_CURSOR
      • 方法三:DBMS_XPLAN.DISPLAY_AWR
      • 方法四:AUTOTRACE

数据库跑批任务占满TEMP表空间时,如果空间资源足够,可以应急扩容TEMP表空间,以避免批量失败。事后可以通过查看占用TEMP表空间高的SQL执行计划,并结合批量的业务逻辑,作进一步分析。

应急处置

查看temp表空间容量(OMF模式):

--查看临时表空间文件以及是否自动扩展
set linesize 200
col file_name format a60
select tablespace_name, file_name,
bytes/1024/1024 size_mb, maxbytes/1024/1024 max_mb,autoextensible 
from dba_temp_files;--查看临时表空间大小以及使用率
select tablespace_name, tablespace_size/1024/1024 size_mb,
free_space/1024/1024 free_mb,
round((1 - nvl(free_space,0)/tablespace_size)*100,2) used_percent 
from dba_temp_free_space;

扩容temp表空间(OMF模式):

--临时表空间扩容
alter tablespace temp add tempfile;

问题排查

查看占用TEMP表空间高的SQL

查看指定时间段内占用TEMP表空间高的SQL:

-- v$active_session_history中记录了当前活动会话的快照信息(取样频率为每秒一次)。
-- v$sql中记录了SQL语句的子游标信息,对于正在执行的SQL,每5s会更新一次信息。
set lines 200
col sample_time for a30
select *from (select t.sample_time,s.PARSING_SCHEMA_NAME,t.sql_id,t.sql_child_number as sql_child,round(t.temp_space_allocated/1024/1024/1024, 2) || ' G' as temp_used,round(t.temp_space_allocated /(select sum(decode(d.autoextensible, 'YES', d.maxbytes, d.bytes))from dba_temp_files d),2) * 100 || ' %' as temp_pct,t.program,t.module,s.SQL_TEXTfrom v$active_session_history t, v$sql swhere t.sample_time > to_date('2023-02-01 02:00:00', 'yyyy-mm-dd hh24:mi:ss')and t.sample_time < to_date('2023-02-01 03:00:00', 'yyyy-mm-dd hh24:mi:ss')and t.temp_space_allocated is not nulland t.sql_id = s.SQL_IDorder by t.temp_space_allocated desc)where rownum < 20order by temp_used desc;

利用上面获取到的SQL_ID,可以查看SQL文本:

select sql_id, sql_fulltext from v$sql where sql_id = 'zhjw76kh3hjs';

获取目标SQL执行计划

方法一:EXPLAIN PLAN FOR

explain plan for <目标SQL文本>;
--例如:
--explain plan for select empno,ename,dname from scott.emp,scott.dept where emp.deptno=dept.deptno;select * from table(dbms_xplan.display);

方法二:DBMS_XPLAN.DISPLAY_CURSOR

查看刚刚执行过的SQL的执行计划:

select * from table(dbms_xplan.display_cursor(null,null,'advanced'));

查看指定sql_id的SQL执行计划:

select * from table(dbms_xplan.display_cursor('sql_id或sql_hash_value',null,'advanced'));
--例如:
--select * from table(dbms_xplan.display_cursor('2zxtkjmt05up',null,'advanced'));

查看指定sql_idsql_hash_value、以及子游标的SQL执行计划:

select sql_text,sql_id,hash_value,child_number from v$sql 
where sql_text like 'select empno,ename%';--代入上面查到的sql_id(或hash_value)、以及child_number
select * from table(dbms_xplan.display_cursor('sql_id或sql_hash_value',
child_cursor_number,'advanced'));

方法三:DBMS_XPLAN.DISPLAY_AWR

查看指定SQL_ID的所有历史执行计划:

select * from table(dbms_xplan.display_awr('sql_id'));

查看指定SQL_ID在指定时间段采用的执行计划PLAN_HASH_VALUE

select distinct b.begin_interval_time, a.sql_id, a.plan_hash_value
from dba_hist_sqlstat a, dba_hist_snapshot b
where sql_id='2zxtkjmt05up' 
and a.snap_id = b.snap_id
and to_char(b.begin_interval_time, 'yyyy-mm-dd hh24:mi:ss') > '2023-02-01 23:59:59';

方法四:AUTOTRACE

AUTOTRACE命令的使用方法如下:

set autotrace {off|on|traceonly} [explain] [stattistics]
  1. SET AUTOTRACE ON

AUTOTRACE默认是关闭的,执行set autotrace on可以在当前session中开启autotrace。开启autotrace后,当前session中随后所有执行的SQL不仅会显示执行结果,还会显示SQL对应的执行计划和资源消耗情况。执行set autotrace off可以关闭autotrace。

  1. SET AUTOTRACE TRACEONLY

与SET AUTOTRACE ON相比,省略了SQL执行结果的具体内容,只会显示执行结果的行数、SQL执行计划和资源消耗情况。

  1. SET AUTOTRACE TRACEONLY EXPLAIN

只显示SQL的执行计划,不会显示SQL执行结果和资源消耗情况。

  1. SET AUTOTRACE TRACEONLY STATISTICS

只显示SQL执行时的资源消耗情况、以及执行结果的行数,不会显示SQL执行结果的具体内容,也不会显示执行计划。

相关内容

热门资讯

劳动人事争议仲裁申请书 劳动人事争议仲裁申请书(15篇)  在人们物质精神需求不断增长的今天,我们会使用上申请书,不同的使用...
转户口申请书模版 转户口申请书模版(精选10篇)  在这个高速发展的时代,需要使用申请的场合越来越多,正确运用申请书可...
教师辞职申请书简短 教师辞职申请书简短(精选10篇)  在眼下市场经济活跃的社会,申请书使用的情况越来越多,在写作上,申...
最通用的员工转正申请书 最通用的员工转正申请书模板  经过三个月的试用期,在各方面已符合公司对员工的的要求。在转正之时,公司...
财产保全申请书范本 财产保全申请书范本  财产保全申请书的定义  财产保全申请书,是在民事案件审理过程中,公民,法人或其...
五岁儿童申请低保范文精选25... 五岁儿童申请低保范文 第一篇尊敬的领导:我叫,__县沙河站镇孟庄村第一组人.年月出生,现年岁,由于原...
职工工伤认定申请书 职工工伤认定申请书  在如今这个年代,我们每个人都可能要用到申请书,不同的使用场景有不同的申请书。写...
国家助学贷款申请书 国家助学贷款申请书(精选10篇)  国家助学贷款是由政府主导、财政贴息、财政和高校共同给予银行一定风...
工厂离职申请书 工厂离职申请书(通用16篇)  随着时代在进步,我们会使用上申请书,申请书是我们平时提出请求的一种书...
贫困户申请书 贫困户申请书模板合集十篇  当下市场经济活跃,交易频繁,申请书在生活中的使用越来越广泛,请注意不同的...
澳洲留学申请书 澳洲留学申请书6篇  当下市场经济活跃,交易频繁,有各项事务需要申请书,通过申请书,我们可以提出自己...
最新入党申请书 最新入党申请书范文(通用6篇)  在市场经济发展迅速的今天,申请书在生活中的使用越来越广泛,正确运用...
家长的同意退学申请书 家长的同意退学申请书(精选14篇)  在经济飞速发展、人们往来越来越密切的今天,申请书在现实生活中使...
申请优惠书范文怎么写优选10... 申请优惠书范文怎么写 第一篇尊敬的各位领导、各位同事,大家好!我是客服部的***,非常荣幸参加这次的...
法院延期开庭申请书_如何向法... 如果要向法院申请延期开庭,要如何写申请书呢?下面是法院延期开庭申请书,欢迎阅读参考。法院延期开庭申请...
教师补助申请格式 教师补助申请格式尊敬的领导:您好!我是xx市大xx镇xx中心小学校的一名教师。很荣幸能够成为教育大军...
封井申请书范文16篇 封井申请书范文 第一篇协 议 书甲方:潍坊锦源水利建筑安装工程有限公司乙方:经甲乙双方相互协商同意,...
民政补助申请书 民政补助申请书(精选5篇)  在现在的社会生活中申请书在现实生活中使用广泛,正确运用申请书可以达到事...
质量保证金退还申请书样本 一、工程质量保证金退还申请书样本工程名称:2009 年省级投资秭归县杨林桥等六个乡镇低丘岗地改造项目...
小学贫困生申请书 小学贫困生申请书  贫困生申请书范文(一)  尊敬的领导:  我叫李xxx,家住东镇镇中羊泉西村,在...