一.TEMP表空间作用

暂时表空间主要用途是在数据库进行排序运算、管理索引、訪问视图等操作时提供暂时的运算空间,当运算完毕之后系统会自己主动清理。当 oracle 里须要用到 sort 的时候。 PGA 中 sort_area_size 大小不够时,将会把数据放入暂时表空间里进行排序,同一时候假设有异常情况的话。也会被放入暂时表空间 , 正常来说。在完毕 Select 语句、create
index 等一些使用 TEMP 表空间的排序操作后, Oracle 是会自己主动释放掉暂时段的。注意这里的释放,不过将这些空间标记为空暇,并可重用,真正占用的磁盘空间并没有释放。所以 Temp 表空间可能会越来越大。

排序是非常耗资源的。 Temp 表空间满了 , 关键是优化你的语句,尽量使排序降低才是上策 .

总结为:

暂时表空间的主要作用:

  索引create或rebuild;

  Order by 或 group by;

  Distinct 操作。

  Union 或 intersect 或 minus。

  Sort-merge joins;

  analyze.

二、oracle
temp表空间切换

2.1
查询TEMP表空间使用情况:

SELECT
temp_used.tablespace_name,

       total - used AS "Free",

       total AS "Total",

       ROUND (NVL (total - used, 0) * 100 / total, 3) "Free percent"

  FROM (  SELECT tablespace_name, SUM (bytes_used) / 1024 / 1024 used

            FROM GV$TEMP_SPACE_HEADER

        GROUP BY tablespace_name) temp_used,

       (  SELECT tablespace_name, SUM (bytes) / 1024 / 1024 total

            FROM dba_temp_files

        GROUP BY tablespace_name) temp_total

 WHERE temp_used.tablespace_name = temp_total.tablespace_name;

数据库默认表空间:

SQL>
SELECT PROPERTY_NAME, PROPERTY_VALUE

  2    FROM DATABASE_PROPERTIES

  3   WHERE PROPERTY_NAME = 'DEFAULT_TEMP_TABLESPACE';

2.2 新建Temp2表空间

create
temporary tablespace temp1 tempfile   'D:\APP\ADMINISTRATOR\ORADATA\SDXJ\TEMP2.dbf' size 20M autoextend on next 1M maxsize unlimited

tablespace group ''

extent management local uniform size 1M;

2.3 改动数据库默认表空间为Temp1

SQL> alter database default temporary tablespace temp1;

  数据库已更改。

2.4 删除原来表空间

退出session,删除原表空间

DROP TABLESPACE TEMP INCLUDING CONTENTS AND DATAFILES;

删除完毕。

三、Temp 表空间一些经常使用查询

3.1、更改系统的默认暂时表空间:

      --查询默认暂时表空间

    select * from database_properties where property_name='DEFAULT_TEMP_TABLESPACE';

     --改动默认暂时表空间

     alter database default temporary tablespace temp1;

      --全部用户的默认暂时表空间都将切换为新的暂时表空间:

     select username,temporary_tablespace,default_ from dba_users;

      --更改某一用户的暂时表空间:

     alter user scott temporary tablespace temp;

3.2 查找消耗资源比較的sql语句

/* Formatted on 2015/7/14 21:58:17 (QP5 v5.163.1008.3004) */

  SELECT se.username,

         se.sid,

         su.extents,

         su.blocks * TO_NUMBER (RTRIM (p.VALUE)) AS Space,

         tablespace,

         segtype,

         sql_text

    FROM v$sort_usage su,

         v$parameter p,

         v$session se,

         v$sql s

   WHERE     p.name = 'db_block_size'

         AND su.session_addr = se.saddr

         AND s.hash_value = su.sqlhash

         AND s.address = su.sqladdr

ORDER BY se.username, se.sid

3.3、查看当前暂时表空间使用大小与正在占用暂时表空间的sql语句

select sess.SID, segtype, blocks * 8 / 1000 "MB", sql_text

  from v$sort_usage sort, v$session sess, v$sql sql

 where sort.SESSION_ADDR = sess.SADDR

   and sql.ADDRESS = sess.SQL_ADDRESS

 order by blocks desc;

4.4
对暂时表空间进行shrink(11g新增的功能)

--将temp表空间收缩为20M

alter tablespace temp1 shrink space keep 20M; 

--自己主动将表空间的暂时文件缩小到最小可能的大小

ALTER TABLESPACE temp1 SHRINK TEMPFILE ’.../temp01.dbf’;

总结: 至此Temp表空间维护完毕。

Oracle Temp 表空间切换的更多相关文章

  1. Oracle Temp表空间切换

    来源于:  http://www.2cto.com/database/201507/418564.html 一.TEMP表空间作用 临时表空间主要用途是在数据库进行排序运算.管理索引.访问视图等操作时 ...

  2. Oracle 临时表空间 temp表空间切换

    一.TEMP表空间 临时表空间主要用途是在数据库进行排序运算.管理索引.访问视图等操作时提供临时的运算空间,当运算完成之后系统会自动清理.当oracle里需要用到sort的时候,PGA中sort_ar ...

  3. oracle暂时表空间 ORA-01652:无法通过16(在表空间XXX中)扩展 temp 字段

    今天在查数据的时候报错  ORA-01652:无法通过16(在表空间temp1中)扩展 temp 字段 查看表空间使用明细 SELECT b.tablespace,        b.segfile# ...

  4. Oracle大表改为分区表及表空间切换方案

    Oracle大表改为分区表及表空间切换方案 一.            背景 由于之前数据库表和索引放在一个表空间导致表空间数据文件增长太快,文件数量即将达到Oracle表空间的限制,需要对表(没有分 ...

  5. oracle维护表空间和数据文件

    1:重要参考 wiki 2: oracle doc 表空间参考 3:来自dba-oracle的参考 26,27,28,29 一:oracle 表空间概念 表空间是联系数据库的物理磁盘(数据文件)和逻辑 ...

  6. 直接删除undo及temp表空间文件后的数据库恢复一例

    前几天,某用户研发找到我,说他们的研发库坏了,问我能恢复不?我问他们做了什么操作,一个小男孩儿说,看到空间满了,清除了点儿数据,我说是不是连数据库的文件也清除了,他说没有,他清除的是ORACLE_HO ...

  7. 解决ora-01652无法通过128(在temp表空间中)扩展temp段的过程

    解决ora-01652无法通过128(在temp表空间中)扩展temp段的过程 昨天开发人员跟我说,执行一个sql语句后,大约花了10分钟,好不容易有一个结果,但是报了一个ora-01652错误,查阅 ...

  8. Oracle创建表空间、用户管理、角色管理

    内容:Oracle创建表空间.用户管理.角色管理 1.用系统用户登录Oracle 默认的系统用户: sys/system.sysman.scott sys:权限最大,超级用户,可以完成所有任务, 默认 ...

  9. Oracle重建表空间操作实例

    由于环境维护或者性能测试需要,经常需要对表空间进行重建操作.重建表空间操作主要分3中情况介绍,分别是业务表空间.临时表空间和回滚段表空间的重建. 重建业务表空间 由于业务规划要求,重建后的业务表空间名 ...

随机推荐

  1. ARP劫持处理指令集

    第一组(据传xp有效,未实验) arp -a arp -d arp -s IP地址 MAC地址 第二组(windows2008R2有效,已实验) netsh i i show in (记住其中本地连接 ...

  2. java_IO_1

    public class DirStudy { public static void main(String[] args) { File file = new File("F:/Eclip ...

  3. 日常开发需要掌握的Git命令

    本人待的两家公司,一直都是用的SVN,Git我只是自己私下学习和开发小项目的时候用过,工作一直没有使用过,但还是要学的... Git是最好的分布式版本控制系统 工作流程 SVN和Git的区别 SVN是 ...

  4. ocelot+consul+identity4的使用demo

    Ocelot网关搭建 搭建core控制台项目 本demo采用2.1版本 命名为APPIGateWay 在Nuget包中添加Ocelot引用 选用8.0.0版本 添加Ocelot.json 文件 内容为 ...

  5. 获取最新ADT下载地址的方法

    最近网络不给力,谷歌上不去,想下个最新的ADT插件也难,于是寻找方法,最后找到一个不错的方法,问题解决过程如下(别嫌我啰嗦啊). 网上有人分享过下载ADT插件的页面地址:install-adt.htm ...

  6. 暴力搜索+散列--P1008 三连击

    题目描述 将1,2, ⋯,9共9个数分成3组,分别组成3个三位数,且使这3个三位数构成1:2:3的比例,试求出所有满足条件的3个三位数. 输入输出格式 输入格式: 木有输入 输出格式: 若干行,每行3 ...

  7. I Think I Need a Houseboat POJ - 1005(数学)

    题目大意 在二维坐标内选定一个点,问你当洪水以半圆形扩散且每年扩散50单位,哪一年这个点被被洪水侵蚀? 解法 代码 #include <iostream> #include <cst ...

  8. LinuxMint19.1安装搜狗拼音输入法

    Installation 1.到搜狗拼音输入法官网下载Linux版. 2.使用dpkg命令安装deb软件包 $ sudo dpkg -i sogoupinyin_2.2.0.0108_amd.deb ...

  9. 爬虫实战(二) 用Python爬取网易云歌单

    最近,博主喜欢上了听歌,但是又苦于找不到好音乐,于是就打算到网易云的歌单中逛逛 本着 "用技术改变生活" 的想法,于是便想着写一个爬虫爬取网易云的歌单,并按播放量自动进行排序 这篇 ...

  10. linux设置系统时间与各种阻塞

    前阵子做了一个P2P的通信系统,发现开机的时候和中间运行的时候会莫名报错,这个问题找了好久,后来从日志中看出来,所有节点上阻塞的操作同时超时. 而在超时左右,有新节点自动加入系统. 在新节点加入系统的 ...