设为首页 收藏本站
查看: 724|回复: 0

[经验分享] 解决oracle临时表空间的报错

[复制链接]

尚未签到

发表于 2018-9-7 10:01:49 | 显示全部楼层 |阅读模式
  报错信息:[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;
DSC0000.jpg

  2、  扩展临时表空间

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

  alter tablespace temp add tempfile‘/u01/app/oracle/oradata/CP7PV1DB/temp02.dbf’>  注:临时表空间文件如果已经32G,达到最大文件大小,只能添加文件。

  SQL>>
  SQL>>
  SQL>>  3、  设置自动扩展

  SQL>>  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> >
  Database>  5、  删除临时表空间(补充)
  SQL>drop tablespace temp01  including contents and datafiles;

  SQL>>
  Database>  注意:删除临时表空间的临时数据文件时,不需要指定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>>  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;
  先创建一个临时表空间,把这个表空间设置为默认的临时表空间,然后把以前的临时表空间删掉,再把数据文件删掉,很简单。
  经验:

  •   Oracle表空间中的数据文件只能增加不能删除.;可以移动数据文件,把表空间的指针rename一下.默认的临时表空间不能脱机.


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-565668-1-1.html 上篇帖子: oracle 11G 静默安装 下篇帖子: Oracle 11g expdp中query参数的使用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表