成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

解決臨時表空間的報錯

開發 開發工具
今天主要講講如何解決臨時表空間的報錯。

報錯信息:[HY000](1652) [Oracle][ODBC][Ora]ORA-01652: 無法通過 128 (在表空間 TEMP 中) 擴展 temp 段

原因分析:oracle臨時表空間不足,事務執行一般將會報ora-01652無法擴展臨時段的錯誤。因為oracle總是盡量分配連續空間,一旦沒有足夠的可分配空間或者分配不連續就會出現上述的現象。

回憶下臨時表空間的作用:

(1)臨時表空間主要用途是在數據庫進行排序運算[如創建索引、order by及group by、distinct、union/intersect/minus/、sort-merge及join、analyze命令]、管理索引[如創建索引、IMP進行數據導入]、訪問視圖等操作時提供臨時的運算空間,當運算完成之后系統會自動清理。

(2)當臨時表空間不足時,表現為運算速度異常的慢,并且臨時表空間迅速增長到***空間(擴展的極限),并且一般不會自動清理了。

解決辦法:我們知道由于ORACLE將表空間作為邏輯結構-單元,而表空間的物理結構是數據文件,數據文件在磁盤上物理地創建,表空間的所有對象也存在于磁盤上,為了給表空間增加空間,就必須增加數據文件。先查看一下指定表空間的可用空間,使用視圖SYS.DBA_FREE_SPACE,視圖中每條記錄代表可用空間的碎片大小。當然也可以擴展表空間。

1、增大臨時表空間(或增加臨時表空間文件)。

2、設置臨時數據文件自動擴展

臨時表空間

步驟:

1、 查詢臨時表空間狀態:

  1. SQL> col file_name for a20; 
  2. SQL> select tablespace_name,file_name,bytes/1024/1024file_size,autoextensible from dba_temp_files;  

查詢臨時表空間狀態

 

2、 擴展臨時表空間

  1. SQL> alter database tempfile '/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf'resize 8192m; 

或也可增加臨時表空間文件

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

注:臨時表空間文件如果已經32G,達到***文件大小,只能添加文件。

3、 設置自動擴展

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

4、 擴展表空間時的報錯

  1. ERROR atline 1: 
  2. ORA-00376:file 201 cannot be read at this time 
  3. ORA-01110:data file 201: '/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf' 

原因是臨時表空間不知道什么原因offline了,修改為online后修改成功。

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

5、 刪除臨時表空間(補充)

  1. SQL>drop tablespace temp01  including contents and datafiles; 
  2. SQL> ALTER DATABASE TEMPFILE  '/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf' DROPINCLUDING DATAFILES; 
  3. Database altered. 

注意:刪除臨時表空間的臨時數據文件時,不需要指定INCLUDING DATAFILES 選項也會真正刪除物理文件,否則需要手工刪除物理文件。也不能直接刪除當前用戶的默認表空間,否則會報ORA-12906錯誤。如果需要刪除某一個默認的臨時表空間,則必須先創建一個臨時表空間,然后指定新創建的表空間為默認表空間,然后刪除原來的臨時表空間。

6、 更改系統默認的臨時表空間

  1. --查詢默認臨時表空間 
  2. SQL> select *from database_properties where property_name='DEFAULT_TEMP_TABLESPACE'
  3. PROPERTY_NAME                  PROPERTY_VALUE       DESCRIPTION 
  4. -------------------------------------------------- -------------------------------------------------- 
  5. DEFAULT_TEMP_TABLESPACE        TEMP       Name of default temporary tablespace 
  6. --修改默認臨時表空間 
  7. SQL> alterdatabase default temporary tablespace temp02; 
  8. Databasealtered. 

我們可以查詢是否切換為TEMP02:

  1. SQL> select *from database_properties where property_name='DEFAULT_TEMP_TABLESPACE'
  2. PROPERTY_NAME                  PROPERTY_VALUE       DESCRIPTION 
  3. -------------------------------------------------- ---------------------------------------- 
  4. DEFAULT_TEMP_TABLESPACE        TEMP02     Name of default temporary tablespace 

7、 查看臨時表空間的使用率

  1. SQL>SELECT temp_used.tablespace_name, 
  2.            total - used as "Free", 
  3.            total as "Total", 
  4.            round(nvl(total - used, 0) * 100 /total, 3) "Free percent" 
  5.       FROM (SELECT tablespace_name,SUM(bytes_used) / 1024 / 1024 used 
  6.               FROM GV_$TEMP_SPACE_HEADER 
  7.              GROUP BY tablespace_name) temp_used, 
  8.            (SELECT tablespace_name, SUM(bytes) /1024 / 1024 total 
  9.               FROM dba_temp_files 
  10.            GROUP BY tablespace_name) temp_total 
  11.     WHEREtemp_used.tablespace_name = temp_total.tablespace_name; 
  12.   
  13. TABLESPACE_NAME                      Free      Total Free percent 
  14. ---------------------------------------- ---------- ------------ 
  15. TEMP                                 6876       8192       83.936 

8、 查找消耗資源比較多的sql語句

  1. Select se.username, 
  2.        se.sid, 
  3.        su.extents, 
  4.        su.blocks * to_number(rtrim(p.value)) asSpace, 
  5.        tablespace, 
  6.        segtype, 
  7.        sql_text 
  8.   from v$sort_usage su, v$parameter p, v$session se, v$sql s 
  9.  where p.name = 'db_block_size' 
  10.    and su.session_addr = se.saddr 
  11.    and s.hash_value = su.sqlhash 
  12.    and s.address = su.sqladdr 
  13.  order by se.username, se.sid; 

【本文為51CTO專欄作者“孫杰”原創稿件,轉載請聯系原作者】

責任編輯:趙寧寧 來源: 51CTO博客
相關推薦

2011-05-20 15:50:06

oracle

2010-11-29 14:47:47

Sybase臨時表

2010-04-02 18:01:39

Oracle清理

2010-03-29 17:03:48

Oracle創建

2022-10-19 21:24:24

臨時表空間Oracle

2011-08-11 18:38:05

Oracle回滾段

2011-07-04 10:33:45

臨時表空間排序

2022-01-26 07:18:57

oracle臨時表空間數據庫

2009-07-02 00:26:00

臨時表空間Oracle數據庫性能

2011-04-13 13:56:52

Oracle臨時表

2010-11-22 15:19:28

Mysql臨時表

2010-07-08 14:24:21

SQL Server

2010-11-03 09:34:39

DB2臨時表

2011-09-02 14:45:43

Oracle臨時表SQL Server臨

2010-10-19 14:45:01

SQL SERVER臨

2011-03-16 09:42:27

Oracle臨時表

2010-04-26 13:38:34

Oracle dele

2010-09-16 15:10:48

SQL Server表

2011-03-29 13:22:07

SQL Server臨時表表變量

2011-08-24 14:21:44

Oracle 10gUNDO表空間
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品在线看 | 超碰激情 | 国产精品久久性 | 九九看片| 观看毛片 | 国产精品永久免费 | 成人精品久久 | 国产一区二区三区免费 | 亚洲情侣视频 | 精品欧美乱码久久久久久1区2区 | 久产久精国产品 | 国内精品99| 欧美激情黄色 | 国产精彩视频一区 | 日本在线视频中文字幕 | 精品欧美一区二区三区久久久 | 日韩二 | 蜜桃免费一区二区三区 | 久久久高清 | 久久精品二区 | 欧美中文字幕在线 | 日本一区二区高清视频 | 精品日韩一区二区三区av动图 | 国产一级片免费视频 | 成人精品国产免费网站 | 国产乱码精品1区2区3区 | 国产精品久久777777 | 在线视频一区二区三区 | 婷婷综合在线 | 国产精品极品美女在线观看免费 | 久久久久久一区 | 中文在线播放 | 久久久久久久国产 | 日韩福利 | 国产露脸国语对白在线 | 四虎免费视频 | 九九热免费视频在线观看 | 欧美黄色免费网站 | 97视频网站 | 国产精品国产成人国产三级 | 午夜精品视频 |