`
kqy7758
  • 浏览: 18485 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Oracle Temp临时表空间处理

阅读更多
Temporary tablespace是oracle里临时表空间,临时表空间主要用途是在数据库进行排序运算、管理索引、访问视图等操作时提供临时的运算空间,当运算完成之后系统会自动清理。当oracle里需要用到sort的时候,PGA中sort_area_size大小不够时,将会把数据放入临时表空间里进行排序,同时如果有异常情况的话,也会被放入临时表空间,正常来说,在完成Select语句、create index等一些使用TEMP表空间的排序操作后,Oracle是会自动释放掉临时段的。但有些有侯我们则会遇到临时段没有被释放,TEMP表空间几乎满的状况,甚至是我们重启了数据库仍没有解决问题。
  排序是很耗资源的,Temp表空间满了,关键是优化你的语句,尽量使排序减少才是上策.

  Temp表空间满时的处理方法:

  一、修改参数(仅适用于8i及8i以下版本)

  修改一下TEMP表空间的storage参数,让Smon进程观注一下临时段,从而达到清理和TEMP表空间的目的。

  SQL>alter tablespace temp increase 1;

  SQL>alter tablespace temp increase 0;

  二:kill session

  1、 使用如下语句a查看一下认谁在用临时段

  SELECT se.username, se.SID, se.serial#, se.sql_address, se.machine, se.program, su.TABLESPACE,

  su.segtype,  su.CONTENTS FROM v$session se, v$sort_usage su

  WHERE se.saddr = su.session_addr

  2、kill正在使用临时段的进程

  SQL>Alter system kill session 'sid,serial#';

  3、把TEMP表空间回缩一下

  SQL>Alter tablespace TEMP coalesce;

  注:

  这处方法只能针对字典管理表空间(Dictionary Managed Tablespace)。于本地管理表空间(LMT:Local Managed Tablespace),不需要整理的。9i以后只能创建本地管理的表空间。

  CREATE TABLESPACE TEST DATAFILE 'D:\TEST01.dbf' SIZE 5M EXTENT MANAGEMENT DICTIONARY

  CREATE TABLESPACE TEST DATAFILE 'D:\TEST01.dbf' SIZE 5M EXTENT MANAGEMENT LOCAL;

  三、重启数据库库

  库重启时,Smon进程会完成临时段释放,TEMP表空间的清理操作,不过很多的时侯我们的库是不允许down的,所以这种方法缺少了一点的应用机会,不过这种方法还是很好用的。

  四、使用诊断事件的一种方法,也是最有效的一种方法

  1、 确定TEMP表空间的ts#

  SQL>select ts#, name from sys.ts$ ;

  TS# NAME

  ---------- ------------------------------

  0 SYSTEM

  1 UNDOTBS1

  2 SYSAUX

  3 TEMP

  4 USERS

  5 UNDOTBS2

  2、 执行清理操作

  SQL>alter session set events 'immediate trace name DROP_SEGMENTS level 4' ;

  说明:

  temp表空间的TS# 为 3, So TS#+ 1= 4

  重建TEMP 表空间:

  Temporary tablespace是不能直接drop默认的临时表空间的,不过我们可以通过以下方法来做。

  准备:查看目前的Temporary Tablespace

  SQL> select name from v$tempfile;

  NAME

  ———————————————————————

  D:\ORACLE\ORADATA\TEST\TEMP01.DBF

  SQL> select username,temporary_tablespace from dba_users;

  USERNAME                    TEMPORARY_TABLESPACE

  ------------------------------ ------------------------------

  MGMT_VIEW
TEMP

  SYS                                  TEMP

  SYSTEM                         TEMP

  DBSNMP                        TEMP

  SYSMAN                         TEMP

  1.创建中转临时表空间

  create temporary tablespace  TEMP1 TEMPFILE 'E:\ORACLE\ORADATA\ORCL\temp02.DBF' SIZE 512M REUSE AUTOEXTEND ON NEXT  1M MAXSIZE UNLIMITED;

  2.改变缺省临时表空间 为刚刚创建的新临时表空间temp1

  alter database default  temporary tablespace  temp1;

  3.删除原来临时表空间

  drop tablespace temp including contents and datafiles;

  4.重新创建临时表空间

  create temporary tablespace  TEMP TEMPFILE 'E:\ORACLE\ORADATA\ORCL\temp01.DBF' SIZE 512M REUSE AUTOEXTEND ON NEXT  1M MAXSIZE UNLIMITED;

  5.重置缺省临时表空间为新建的temp表空间

  alter database default  temporary tablespace  temp;

  6.删除中转用临时表空间

  drop tablespace temp1 including contents and datafiles;

  7.如果有必要,那么重新指定用户表空间为重建的临时表空间

  alter user arbor temporary tablespace  temp;

  查看表空间语句,不过查不出Temp表空间:

  SELECT UPPER(F.TABLESPACE_NAME) "表空间名",

  D.TOT_GROOTTE_MB "表空间大小(M)",

  D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",

  TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),

  '990.99') "使用比",

  F.TOTAL_BYTES "空闲空间(M)",

  F.MAX_BYTES "最大块(M)"

  FROM (SELECT TABLESPACE_NAME,

  ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,

  ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTES

  FROM SYS.DBA_FREE_SPACE

  GROUP BY TABLESPACE_NAME) F,

  (SELECT DD.TABLESPACE_NAME,

  ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MB

  FROM SYS.DBA_DATA_FILES DD

  GROUP BY DD.TABLESPACE_NAME) D

  WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME

  ORDER BY 4 DESC


转自http://news.newhua.com/news1/program_database/2010/811/1081114432241187KG9D6DH0G90KFCIC51D6F0DAAI2DG179KJH9n_2.html?lt=common
分享到:
评论

相关推荐

    Oracle临时表空间满的解决步骤

    解决 Oracle 临时表空间满的问题需要通过查看当前数据库的默认临时表空间、查看当前临时表空间的大小、创建新的临时表空间、将新建的临时表空间设置为数据库的默认临时表空间、删除原来的临时表空间、创建新的临时表...

    oracle temp表空间不足解决方法

    - 设置全局临时表:对于临时数据,可以使用全局临时表,它们在会话结束时自动删除,可以有效地管理Temp表空间。 7. **调整SGA参数**: - 调整 sort_area_size 和 sort_area_retained_size 参数,控制排序操作在...

    Oracle的Temp表空间和UNDO表空间的处理

    如果Temp表空间中有数据正在使用,则可以考虑创建一个新的临时表空间,并将其设置为默认的临时表空间,然后再删除旧的表空间。步骤如下: 1. **创建新表空间**: ```sql CREATE TEMPORARY TABLESPACE TEMP1 TEMP...

    Oracle临时表空间不足和批处理缓慢问题探讨.pdf

    Oracle 临时表空间不足和批处理缓慢问题探讨 本文探讨了 Oracle 临时表空间不足和批处理缓慢问题的原因和解决方法。通过分析和测试,发现了问题的根源在于应用逻辑方面,具体来说是 SQL 语句的编写问题。通过编写...

    Oracle释放临时表空间脚本

    ### Oracle 临时表空间管理与释放脚本解析 在Oracle数据库管理中,临时表空间(Temporary Tablespace)的管理是一项非常重要的任务。合理的管理和优化临时表空间不仅可以提高系统的性能,还可以帮助解决空间不足等...

    oracle-临时表空间

    因此,临时表空间非常适合用于那些不需要长期保留的数据处理场景。 #### 三、查询与管理临时表空间 ##### 1. 查询用户及其关联的临时表空间 为了了解某个用户的临时表空间设置情况,可以通过以下SQL查询语句获取...

    学习oracle创建一个表空间创建临时表空间创建用户表空间资源的权限

    在Oracle数据库系统中,表空间(Tablespace)是存储数据对象(如表、索引、视图等)的逻辑单位,而临时表空间(Temporary Tablespace)则用于存储临时数据,比如排序或联接操作产生的中间结果。创建和管理表空间及...

    Oracle 临时表用法

    为了解决这个问题,可以通过使用Oracle临时表来提高处理效率。本文将详细介绍Oracle临时表的创建方法、使用场景以及优缺点,帮助读者更好地理解和运用这一特性。 #### 二、Oracle临时表概述 Oracle临时表是一种...

    如何解决Oracle8i数据库临时表空间满的问题.pdf

    4. Oracle临时表空间满的问题:当临时表空间的磁盘空间被全部占用后,可能会出现错误消息,例如“ORA-1652: unable to extend temp segment by %s in tablespace %s”。这会导致用户无法完成如排序、并行查询等操作...

    oracle创建临时表空间文档及工具

    4. **游标处理**:在处理大型游标时,Oracle可能会将数据存储在临时表空间中。 在实际工作中,我们可能需要导入和导出数据,这就涉及到了数据库的备份和迁移。这里提到的一键导入、导出工具,可能是Oracle的Data ...

    Oracle临时表空间处理.txt

    ### Oracle 临时表空间管理详解 #### 一、概述 Oracle 数据库中的临时表空间主要用于存储临时对象,如排序操作、表连接等过程中产生的临时数据。这些数据在事务结束后会被自动清除,不会占用永久存储空间。正确管理...

    oracle11g创建临时表空间组

    ### Oracle 11g 创建临时表空间组 在Oracle 11g R2版本中,引入了临时表空间组的概念,这一特性为数据库管理提供了更大的灵活性。与传统的单个临时表空间相比,临时表空间组允许多个临时表空间协同工作,从而提高...

    释放TEMP表空间占用硬盘空间

    标题与描述概述的知识点主要涉及Oracle数据库中临时表空间(TEMP表空间)的管理与优化,特别是当TEMP表空间占用过多硬盘空间时的处理方法。本文将深入解析这一过程,帮助读者理解并掌握释放TEMP表空间所占用硬盘空间...

    修改Nagios的checkoracle脚本来监控Oracle的临时表空间.pdf

    此外,还需要确保脚本能够处理多个临时表空间,而不仅仅是名为"TEMP"的默认临时表空间。 在修改后的脚本中,除了增加新的查询逻辑,还需要更新错误处理和输出报告的部分,确保监控结果能够正确地反映在Nagios的监控...

    ORACLE修改表空间大小

    当Oracle数据库执行涉及排序、连接等操作时,会使用临时表空间来存储临时数据。如果这些操作所需的空间超过了临时表空间的可用空间,就会引发ORA-01652错误。 #### 二、ORA-01652 错误分析 ##### 1. 错误现象 当...

    Oracle存储过程中使用临时表

    总结来说,Oracle存储过程中使用临时表是优化数据处理和提高性能的有效手段,正确理解和运用会话级和事务级临时表,能更好地满足复杂的业务需求。在设计和实现存储过程时,应根据具体的应用场景选择合适的临时表类型...

    Oracle特性临时表

    ### Oracle特性临时表详解 #### 一、临时表概述 ...总之,Oracle中的临时表为开发者提供了强大的功能,可以在不影响永久数据的情况下高效地处理临时性数据。理解并合理利用临时表可以显著提升应用程序的性能和效率。

    Oracle创建表空间、临时表、用户及用户授权

    在Oracle数据库管理中,表空间(Tablespaces)、临时表(Temporary Tables)、用户(Users)以及用户授权(User Authorization)是数据库管理员(DBA)进行数据库架构设计和安全管理的基础操作。以下将详细介绍这些...

    oracle定时删除表空间的数据并释放表空间

    同时,为了释放表空间,需要创建一个临时表,复制原表的所有数据到临时表,然后删除原表,最后再将临时表的数据插入到原表。 代码如下: ```sql create or replace procedure del_tab as v_time number; begin ...

    一个释放临时表空间实例

    临时表空间在查询优化、数据处理和分析中扮演着关键角色。当执行涉及排序、分组、去重、联合、交集或差集等操作的SQL语句时,Oracle会利用临时表空间来提高性能。 临时表空间的使用是动态的,其大小会根据实际需求...

Global site tag (gtag.js) - Google Analytics