Oracle 临时表空间管理(Temporary Tablespace)

2024-03-17 06:36

本文主要是介绍Oracle 临时表空间管理(Temporary Tablespace),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Oracle临时表空间(Temporary Tablespace)主要用来存储数据库运行中产生的临时对象,例如SQL排序结果集,临时表等,这些对象的生存周期只有会话。本文总结了Oralce中涉及临时表空间的管理和优化操作。

目录

  • 一、临时表空间简介
  • 二、临时表空间管理
    • 2.1 创建临时表空间
    • 2.2 修改临时表空间
    • 2.3 查看空间使用情况
    • 2.4 收缩临时表空间
    • 2.5 删除临时表空间
  • 三、使用临时表空间组

一、临时表空间简介

在执行SQL时,经常会遇到排序操作,当结果集无法放在内存中时,Oracle就会使用临时表空间来排序。临时表空间中不能创建持久性对象,用户唯一能创建的就是临时表,而且随着用户会话退出,临时表也会被删除。

当Oracle安装完成时,默认就已经创建了1个临时表空间TEMP,且所有未显式指定使用其他临时表空间的用户,都会使用这个临时表空间,使用下面的SQL可以查询数据库的默认临时表空间:

select property_name, property_value
from database_properties
where property_name='DEFAULT_TEMP_TABLESPACE';

在这里插入图片描述

临时表空间的底层使用的是临时文件(tempfile),通常采用本地管理策略(Locally Management),临时表空间不会生成redo日志,根据其服务的实例数量还可以分为:

  • 本地临时表空间,通常保存在本地磁盘,只能给一个实例访问
  • 共享临时表空间:通常保存在共享存储上,可以被多个实例同时访问

二、临时表空间管理

虽然Oracle初始已经建立了一个临时表空间,但用户也可以根据自身需求对临时表空间进行定制。

2.1 创建临时表空间

使用create temporary tablespace语句创建临时表空间,语法和创建普通表空间类似,不同点在于其需要指定temporary和tempfile关键字。

示例:创建一个临时表空间temptbs01,文件大小20M,reuse关键字指示如果文件已存在则重用:

create temporary tablespace temptbs01 
tempfile '/u01/app/oracle/oradata/PROD/temptbs01.dbf' size 20m reuse;

在这里插入图片描述

如果开启了OMF特性,可以不指定文件属性,只提供表空间名称即可:

create temporary tablespace temptbs02;

在这里插入图片描述

创建好的临时表空间及其临时文件信息可以通过dba_temp_files查看:

select tablespace_name, file_name,status, autoextensible from dba_temp_files;

在这里插入图片描述

2.2 修改临时表空间

可以用alter tablespace语句修改表空间属性,例如添加,删除临时文件,修改在线/离线状态,调整临时文件大小等。

示例:为temptbs01添加一个数据文件,大小10M,自动扩展:

alter tablespace temptbs01 
add tempfile '/u01/app/oracle/oradata/PROD/temptbs01_2.dbf' size 10M 
autoextend on next 10m; 

在这里插入图片描述

示例:将上面添加的数据文件删除:

alter tablespace temptbs01 
drop tempfile '/u01/app/oracle/oradata/PROD/temptbs01_2.dbf';

在这里插入图片描述

示例:修改temptbs01临时文件的在线/离线状态(不能修改临时表空间的在线/离线状态):

alter database tempfile '/u01/app/oracle/oradata/PROD/temptbs01.dbf' offline;
alter database tempfile '/u01/app/oracle/oradata/PROD/temptbs01.dbf' online;

在这里插入图片描述

示例:修改临时文件的大小,将temptbs01的临时文件修改为30m:

alter database tempfile '/u01/app/oracle/oradata/PROD/temptbs01.dbf' resize 30m;

在这里插入图片描述

2.3 查看空间使用情况

查询dba_temp_free_space视图可以查看当前临时表空间的使用情况,free_space字段指示了可用空间:

select * from dba_temp_free_space;

在这里插入图片描述

2.4 收缩临时表空间

对于文件可以自动扩展的临时表空间,当空间不够时,Oracle会自动扩展文件大小,一个很大的任务,就可以导致临时表空间消耗很多磁盘。如果日常用不到这么大的表空间,可以手动收缩以回收磁盘空间。

回收表空间是一个在线操作,正在使用的会话可以正常分配空间,不受影响。

示例:用alter tablespace … shrink space …; 可以回收可用空间,keep子句指示尽量收缩到25m:

alter tablespace temptbs01 shrink space keep 25m;

在这里插入图片描述

或:用alter tablespace … shrink tempfile …; 指定收缩某个临时文件:

alter tablespace temptbs01 shrink tempfile '/u01/app/oracle/oradata/PROD/temptbs01.dbf' keep 20m;

在这里插入图片描述

2.5 删除临时表空间

使用alter tablespace … drop…;语句可以删除临时表空间,你可以选择是否保留临时文件,如果保留临时文件,下次再次指定同名文件时需要用reuse关键字重用文件。

示例:删除临时表空间temptbs01及其临时文件,省略including contents and datafiles子句则会保留临时文件:

drop tablespace temptbs01 including contents and datafiles;

在这里插入图片描述

三、使用临时表空间组

临时表空间组是一个逻辑概念,它由1或多个临时表空间组成,可以作为一个整体分配给数据库或用户使用。在高并发环境,多个临时表空间可以更好的减少争用现象,并且Oracle的并行执行特性也可以利用多个临时表空间提升执行性能。

临时表空间组不需要显式创建,只需要使用alter tablespace … tablespace group …; 将某个临时表空间加入组即可(创建表空间时也可加入)。

第一步,将temptbs01加入组group1,这会隐式创建group1:

alter tablespace temptbs01 tablespace group group1;

在这里插入图片描述

第二步(可选),可以继续将其他临时表空间加入组,组成员的数量没有限制:

alter tablespace temptbs02 tablespace group group1;

在这里插入图片描述

通过dba_tablespace_groups可以看到目前group1中已经有2个表空间:

select * from dba_tablespace_groups;

在这里插入图片描述

第三步:将组指定为数据库默认临时表空间(alter database)或指定给用户(alter user):

alter database default temporary tablespace group1;
alter user hr temporary tablespace group1;

在这里插入图片描述

使用alter database指定空的组名可以将临时表空间移出组,当最后一个表空间移出组时,组自动删除(先取消引用):

alter tablespace temptbs01 tablespace group '';

在这里插入图片描述

这篇关于Oracle 临时表空间管理(Temporary Tablespace)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/818117

相关文章

gradle第三方Jar包依赖统一管理方式

《gradle第三方Jar包依赖统一管理方式》:本文主要介绍gradle第三方Jar包依赖统一管理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景实现1.顶层模块build.gradle添加依赖管理插件2.顶层模块build.gradle添加所有管理依赖包

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

SpringBoot内嵌Tomcat临时目录问题及解决

《SpringBoot内嵌Tomcat临时目录问题及解决》:本文主要介绍SpringBoot内嵌Tomcat临时目录问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录SprinjavascriptgBoot内嵌Tomcat临时目录问题1.背景2.方案3.代码中配置t

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

Spring 基于XML配置 bean管理 Bean-IOC的方法

《Spring基于XML配置bean管理Bean-IOC的方法》:本文主要介绍Spring基于XML配置bean管理Bean-IOC的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录一. spring学习的核心内容二. 基于 XML 配置 bean1. 通过类型来获取 bean2. 通过

python uv包管理小结

《pythonuv包管理小结》uv是一个高性能的Python包管理工具,它不仅能够高效地处理包管理和依赖解析,还提供了对Python版本管理的支持,本文主要介绍了pythonuv包管理小结,具有一... 目录安装 uv使用 uv 管理 python 版本安装指定版本的 Python查看已安装的 Python

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Linux修改pip临时目录方法的详解

《Linux修改pip临时目录方法的详解》在Linux系统中,pip在安装Python包时会使用临时目录(TMPDIR),但默认的临时目录可能会受到存储空间不足或权限问题的影响,所以本文将详细介绍如何... 目录引言一、为什么要修改 pip 的临时目录?1. 解决存储空间不足的问题2. 解决权限问题3. 提

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.