日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
解決臨時表空間的報錯

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

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、小程序設(shè)計、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了宕昌免費建站歡迎大家使用!

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

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

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

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

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

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

2、設(shè)置臨時數(shù)據(jù)文件自動擴(kuò)展

步驟:

1、 查詢臨時表空間狀態(tài):

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

2、 擴(kuò)展臨時表空間

 
 
  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;

注:臨時表空間文件如果已經(jīng)32G,達(dá)到***文件大小,只能添加文件。

3、 設(shè)置自動擴(kuò)展

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

4、 擴(kuò)展表空間時的報錯

 
 
  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、 刪除臨時表空間(補(bǔ)充)

 
 
  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.

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

6、 更改系統(tǒng)默認(rèn)的臨時表空間

 
 
  1. --查詢默認(rèn)臨時表空間
  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. --修改默認(rèn)臨時表空間
  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;

【本文為專欄作者“孫杰”原創(chuàng)稿件,轉(zhuǎn)載請聯(lián)系原作者】


分享題目:解決臨時表空間的報錯
文章分享:http://www.dlmjj.cn/article/djccpjj.html