解决临时表空间的报错

报错信息:[HY000](1652) [Oracle][ODBC][Ora]ORA-01652: 无法通过 128 (在表空间 TEMP 中) 扩展 temp 段

原因分析:oracle临时表空间不足,事务执行一般将会报ora-01652无法扩展临时段的错误。因为oracle总是尽量分配连续空间,一旦没有足够的可分配空间或者分配不连续就会出现上述的现象。

回忆下临时表空间的作用:

  临时表空间主要用途是在数据库进行排序运算[如创建索引、order by及group by、distinct、union/intersect/minus/、sort-merge及join、analyze命令]、管理索引[如创建索引、IMP进行数据导入]、访问视图等操作时提供临时的运算空间,当运算完成之后系统会自动清理。

当临时表空间不足时,表现为运算速度异常的慢,并且临时表空间迅速增长到最大空间(扩展的极限),并且一般不会自动清理了。

解决办法:我们知道由于ORACLE将表空间作为逻辑结构-单元,而表空间的物理结构是数据文件,数据文件在磁盘上物理地创建,表空间的所有对象也存在于磁盘上,为了给表空间增加空间,就必须增加数据文件。先查看一下指定表空间的可用空间,使用视图SYS.DBA_FREE_SPACE,视图中每条记录代表可用空间的碎片大小。当然也可以扩展表空间。

1、增大临时表空间(或增加临时表空间文件)。

2、设置临时数据文件自动扩展

步骤:

1、  查询临时表空间状态:  
SQL> col file_name for a20;

SQL> select tablespace_name,file_name,bytes/1024/1024file_size,autoextensible from dba_temp_files;   

2、  扩展临时表空间
SQL> alter database tempfile ‘/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf‘resize 8192m;

或也可增加临时表空间文件

alter tablespace temp add tempfile‘/u01/app/oracle/oradata/CP7PV1DB/temp02.dbf’ size 8192m;

注:临时表空间文件如果已经32G,达到最大文件大小,只能添加文件。

3、  设置自动扩展

SQL> alter database tempfile‘/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf‘ autoextend on next 10m maxsizeunlimited;

4、  扩展表空间时的报错

ERROR atline 1:

ORA-00376:file 201 cannot be read at this time

ORA-01110:data file 201: ‘/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf‘

原因是临时表空间不知道什么原因offline了,修改为online后修改成功。

SQL>  alter database tempfile ‘/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf’online;

Database altered.

5、  删除临时表空间(补充)

SQL>drop tablespace temp01  including contents and datafiles;

SQL> ALTER DATABASE TEMPFILE  ‘/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf‘ DROPINCLUDING DATAFILES;

Database altered.

注意:删除临时表空间的临时数据文件时,不需要指定INCLUDING DATAFILES 选项也会真正删除物理文件,否则需要手工删除物理文件。也不能直接删除当前用户的默认表空间,否则会报ORA-12906错误。如果需要删除某一个默认的临时表空间,则必须先创建一个临时表空间,然后指定新创建的表空间为默认表空间,然后删除原来的临时表空间。

6、  更改系统默认的临时表空间

--查询默认临时表空间

SQL> select *from database_properties where property_name=‘DEFAULT_TEMP_TABLESPACE‘;

PROPERTY_NAME                  PROPERTY_VALUE       DESCRIPTION

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

DEFAULT_TEMP_TABLESPACE        TEMP       Name of default temporary tablespace

--修改默认临时表空间

SQL> alterdatabase default temporary tablespace temp02;

Databasealtered.

我们可以查询是否切换为TEMP02:

SQL> select *from database_properties where property_name=‘DEFAULT_TEMP_TABLESPACE‘;

PROPERTY_NAME                  PROPERTY_VALUE       DESCRIPTION

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

DEFAULT_TEMP_TABLESPACE        TEMP02     Name of default temporary tablespace

7、  查看临时表空间的使用率

SQL>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

WHEREtemp_used.tablespace_name = temp_total.tablespace_name;

TABLESPACE_NAME                      Free      Total Free percent

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

TEMP                                 6876       8192       83.936

8、  查找消耗资源比较多的sql语句

Select se.username,
       se.sid,
       su.extents,
       su.blocks * to_number(rtrim(p.value)) asSpace,
       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;

时间: 2024-10-21 15:57:45

解决临时表空间的报错的相关文章

解决一个报表EdmFunction报错问题

    最近测试组提了一个bug,说是某个报表点击查询报错,查看错误log,错误信息如下. 类型"Ticket.Data.SqlFuns"上指定的方法"Boolean ContainsAll(System.String, System.String)"无法转换为 LINQ to Entities 存储表达式. 定位到错误行,发现是一个自定义的SQLCLR函数,如下代码. 为什么使用CLR函数ContainsAll报错 理论上CLR函数可以用在lambda表达式中,但

解决SCCM 1606安装报错一例

解决SCCM 1606安装报错一例 这几天在公司测试SCCM 2016时遇到了如下错误: 博主在安装SCCM 2016时遇到了如下图所示的错误 错误提示:"在执行文件操作是,安装程序遇到错误,有关详细信息,请单击"查看日志"按钮": 打开日志显示如下内容: 错误原因如下: 因为安装SCCM时需要下载一些文件,楼主手欠将文件夹命名成带有中文字样的,如下图所示: 解决方法: 将安装SCCM时下载的文件名称命名为英文样式: 安装成功:

解决eclipse spring配置报错:cvc-elt.1: Cannot find the declaration of element

解决eclipse spring配置报错:cvc-elt.1: Cannot find the declaration of element 'beans'.Referenced file contains errors (http://www.springframework.org/schema/aop/spring-aop-3.1.xsd). 原因是无法从网络上读取到相应的schema文件,但实际上在浏览器中是可以访问的.却一直在eclipse中显示红叉,当然,并不影响编译打包. 查看所依赖

C# 解决SharpSvn启动窗口报错 Unable to connect to a repository at URL 'svn://....'

在远程机打开sharpsvn客户端测试,结果报错 Svn启动窗口报错 Unable to connect to a repository at URL 'svn://...' 咋整,我在win10我的开发环境上没报错啊, 一时间各种的想象, 昨天先是svn客户端不能再win7上运行,后来编译平台换成X86模式,sharpsvn.dll 换成x86,问题解决 .注意:必须删除原先生成的bin文件,当时我只删除了exe文件,结果还是报错,debug 模式和 Release 都要换到x86 . 接着点

Mysql备份迁移——MySqlBackup——(无法解决视图嵌视图报错)

这里是利用MySqlBackup,可以再nuget中下载. 无法解决视图嵌视图报错的问题,只导表跟数据比较合适,如果有视图嵌视图,请参照Mysql备份迁移——Mysqldump(.NET调用Mysqldump.exe方式)——(解决视图嵌视图报错)http://www.cnblogs.com/pbys/p/4142367.html string constring = "server=192.168.0.1;port=3306;user=root; pwd=123456; database=te

1130 - Host'xxx.xxx.xxx.xxx' is not allowed to connect to this MySQL server解决Navicat连接MySQL报错

最近使用Navicat for MySQl访问远程mysql数据库,出现报错,显示"1130 - Host'xxx.xxx.xxx.xxx' is not allowed to connect to this MySQL server".解决办法如下: 方法/步骤 首先看报错窗口. 经查阅,错误原因是:本地IP(xxx.xxx.xxx.xxx)没有访问远程数据库的权限. 于是下面开启本地IP(xxx.xxx.xxx.xxx)对远程mysql数据库的访问权限. 首先远程连接进入服务器,在

解决:pipenv shell报错:AttributeError: 'module' object has no attribute 'run'

利用pipenv shell切换到虚拟环境时,显示报错:AttributeError: 'module' object has no attribute 'run' 可以看到是d:\program\python34\lib\site-packages\pipenv\shells.py文件的第62行报错了,提示模块没有run的属性,于是就跑到该文件的第62行去看 选中run,CTRL+B发现能看到源码,源码如下: if sys.version_info >= (3, 6): # Nearly sa

如何解决金蝶IKernel.exe报错 Windows Installer 错误 重新安装、无法卸载

如何解决金蝶IKernel.exe报错 Windows Installer 错误 金蝶这个小婊子,就是这么贱. 卸载了高版本的,再安装低版本就不能安装上,死活都不能安装. 请手动启动一下InstallService 服务,这个小婊子就让你制服了. 如果还不行,那么请去k3help.kingdee.com下载注册表清除工具,都清理一下,再安装,完美解决.   重新安装,提升已经安装了需要卸载,但就是卸载不掉,那么之间删除这个文件夹就好了 C:\Program Files (x86)\Install

解决cron无法运行报错:FAILED

解决cron无法运行报错:FAILED to authorize user with PAM (Module is unknown) 查看cron运行日志tail -f /var/log/cron报如下错误: May 8 10:14:01 localhost crond[9399]: (root) FAILED to authorize user with PAM (Module is unknown) May 8 10:14:01 localhost crond[9400]: (root) F