国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Oracle臨時表游標未釋放導致回滾段空間不足的解決方案

數據庫 Oracle
本文我們主要介紹了Oracle臨時表游標未釋放導致回滾段空間不足的解決方案,希望能夠對您有所幫助。

Oracle臨時表游標未釋放導致回滾段空間不足時會報出多個ORA-01650錯誤,造成數據庫無法運行。本文我們主要就介紹了這一問題的解決方案,接下來就讓我們來一起了解一下這部分內容。

先分析一下相關背景。產生報錯的程序是一個數據處理模塊,每天會將其他系統傳過來的平面文件中的內容處理后放入數據庫中,事務量很大。我們的系統是9i,劃分了16個回滾段,其中兩個大的batch回滾段,每個batch回滾段有6G的足夠空間。而數據處理模塊會在事務中指定使用BATCH1。

再分析報錯的模塊。檢查相關的數據事務處理部分,由于業務需要保持數據的一致性,需要處理完1個文件后才能提交,中間如果出錯就要全部回滾。經過確認,這部分代碼有很長時間沒有做改動了。然后再確認數據量,可以確認,今天(周五)是一周之內文件內容最少的一天。也就是說,如果由于數據量引起錯誤,其他時間的概率應該更大。

但是,有一點需要注意。指定回滾段是針對事務的,不是針對回滾段。也就是說,我們可以指定某個事務只使用某個回滾段,但是不能保證這個回滾段只被這個事務事務。當一個事務申請使用回滾段時,如果沒有自己指定,oracle就會根據當時的各個回滾段的使用情況,分配一個最合適的回滾段給這個事務使用。因此,報回滾段空間不足的事務可能不一定就是導致回滾段空間不足的事務。還有一種可能就是,事務所指定的回滾段被其他事務所占用了。

于是我們就檢查是否還有其他事務占用了該回滾段。

  1. SELECT s.sid, s.username, s.osuser, s.machine, s.program,  
  2. t.xidusn,t.ubafil,t.ubablk,t.used_ublk, t.log_io, t.phy_io, t.cr_get, t.cr_change,  
  3. r.name, q.sql_text  
  4. FROM v$session s,v$transaction t, v$RollName r, v$sqlarea q  
  5. WHERE s.saddr=t.ses_addr  
  6. and t.xidusn = r.usn  
  7. and s.sql_address = q.address(+)  
  8. and s.sql_hash_value = q.hash_value(+)And r,name = 'RBS_BATCH1'

 

果然發現有5個事務在占用BATCH1。但是發現會話狀態為INACTIVE。這說明它們當時并沒有運行INSERT/UPDATE/DELETE語句(曾經運行過,事務沒有結束),而是將回滾段資源hung住了。

再查下那些對象被hung在BATCH1中,

 

  1. select l.session_id, l.os_user_name, l.oracle_username, o.owner, o.object_name, t.xidusn,t.ubafil,t.ubablk,t.used_ublk, t.used_urec,  
  2. t.log_io, t.phy_io, t.cr_get, t.cr_change, r.name  
  3. from v$locked_object l, dba_objects o, v$transaction t, v$RollName r  
  4. where l.object_id = o.object_id  
  5. and l.xidusn = t.xidusn  
  6. and l.xidslot = t.xidslot  
  7. and l.xidsqn = t.xidsqn  
  8. and t.xidusn = r.usn; 

 

嗯,都是同一個對象:“TMP_CNT_GRP”。通過SID確認,確實上面的事務都是將這個對象hung在RBS中的。

經過檢查,原來這個對象是一個臨時表。我們知道,臨時表對象平時是不存在數據的。只有當一個會話使用臨時表,并向表中插入數據后,oracle才會在臨時表空間上創建它的數據對象。臨時表數據之所以只被所調用會話看到,是實際上是在每個會話中創建了一個單獨的數據對象,有各自的數據對象標號。因此盡管是同一個臨時表,每個會話只是copy一個表結構,而創建了不同的數據對象,這樣,會話之間就不會有數據干擾。而在一個會話中,對臨時表數據對象的處理跟普通數據對象處理基本相同,其中就包括臨時表對象在事務中的數據改動也會有回滾信息的產生。

回到我們的問題中。通過V$SESSION和V$SQL_AREA查到,這些會話都是調用了一個PLSQL函數,而且都是通過java調用的。

Review代碼,終于發現潛在問題了:這個函數的結果是返回一個游標,而游標恰恰關聯了這張臨時表。

 

  1. INSERT INTO TMP_CNT_GRP ...  
  2.     SELECT...... ...      open v_cursor FOR  
  3.  select TMP.CDE,  
  4.          CAR.ID,  
  5.          CAR.NME,  
  6.          COUNT(DISTINCT TMP.NUM) TOTAL_CNT  
  7.    from TMP_CNT_GRP       TMP,  
  8.         CSS_CAR           CAR  
  9.    WHERE TMP.ID    = CAR.ID  
  10.   GROUP BY TMP.CDE, CAR.ID, CAR.NME;  
  11.  
  12.  RETURN v_cursor;  
  13.  
  14.  DELETE TMP_CNT_GRP; 

 

(這段代碼其實還存在一個問題,也就是***的DELETE語句根本不會被調用)

從這段代碼中可以看到,實際上在整個函數當中,臨時表的數據根本不會被釋放;而且也沒有提交和回滾事務(盡管這是一個會話級的臨時表)。占用的回滾段也不會被釋放。這就存在這樣的潛在問題,如果調用者不關閉會話或提交/回滾事務的話,它所占用的回滾段就不會被釋放。事實上,經過讓java開發人員檢查代碼,果然發現客戶端在打開會話后,就沒有關閉,知道客戶端本身結束。

解決辦法:

1、因為這是一個會話級的臨時表,數據在事務提交后繼續保留,因此在PLSQL函數中的insert語句后加上commit;

2、Java代碼在使用完游標后關閉會話。

關于Oracle數據庫的臨時表游標未釋放導致回滾段空間不足的問題就介紹到這里了,希望本次的介紹能夠對您有所幫助。

【編輯推薦】

  1. 關于Oracle數據庫閃回個性的詳細介紹
  2. Oracle數據庫對DDL語句和DML語句的事務管理
  3. Oracle數據庫啟動參數文件及相關SQL語句簡介
  4. Oracle數據庫的幾種文件及表空間數據塊的知識簡介
  5. Oracle數據庫查詢登錄用戶名所屬表空間及其使用情況
責任編輯:趙鵬 來源: 火魔網
相關推薦

2010-04-16 17:31:22

ORACLE回滾段

2009-11-16 17:15:12

Oracle減少回滾段

2009-11-16 13:41:18

Oracle分離回滾段

2011-08-24 14:21:44

Oracle 10gUNDO表空間

2011-07-29 16:21:21

Oracle數據庫回滾段

2018-03-14 19:39:31

數據庫Oracle臨時表

2016-12-27 15:47:19

臨時表空間數據

2010-04-26 13:38:34

Oracle dele

2010-04-28 11:48:13

Oracle MySQ

2010-05-05 17:46:07

Oracle7.X

2010-03-29 17:17:54

Oracle 刪除

2011-05-20 15:50:06

oracle

2010-10-28 13:53:13

ORACLE存儲過程

2010-04-28 18:49:10

Oracle臨時表

2010-04-02 18:01:39

Oracle清理

2010-04-08 15:59:50

Oracle undo

2010-03-29 17:03:48

Oracle創建

2022-10-19 21:24:24

臨時表空間Oracle

2010-04-23 12:39:02

Oracle7.X 回

2025-05-26 03:55:00

MySQLCrash代碼
點贊
收藏

51CTO技術棧公眾號

久久综合狠狠综合久久激情| 91av一区二区三区| 老汉色老汉首页av亚洲| 国内外成人免费激情在线视频网站 | 国产黄色片在线观看| 精品三级在线观看| 国产精品亚洲四区在线观看| 国产精品小说在线| 人人精品人人爱| 欧美视频在线观看视频| 亚洲黄网站在线观看| www免费在线观看| 欧美猛交免费看| 精品9999| 四虎永久在线精品无码视频| 精品国产乱码久久久久久虫虫漫画| 成人影院www在线观看| 九九热视频这里只有精品| 激情久久久久久| 欧美v在线观看| 欧美三级韩国三级日本一级| 九九久久国产| 成人精品一二区| 91丨九色porny丨蝌蚪| 精品久久av| 中文字幕免费精品一区高清| 91精品国产调教在线观看| 国内少妇毛片视频| 欧美午夜电影在线| 欧美电影免费观看| www.久久爱.cn| 国产亚洲精品bt天堂精选| 免费黄网在线观看| 91国产美女视频| 午夜一区不卡| 毛片视频免费| 中文字幕精品www乱入免费视频| 亚洲欧洲日韩| 狠狠热免费视频| 精品国内片67194| 精品国产一区二区三区香蕉沈先生 | 91国产中文字幕| 蜜臀av性久久久久蜜臀aⅴ流畅| 三上悠亚一区二区三区| 中文字幕精品视频| 亚洲国产日本| 国产午夜电影| 国语自产偷拍精品视频偷 | 肉体视频在线| 国产伦精品一区二区三区在线| 欧美国产97人人爽人人喊| 成人精品一区二区三区免费| 午夜免费久久久久| 成人性生交大片免费看中文网站| 午夜激情视频在线| 国产精品丝袜白浆摸在线| 久久久久国产精品麻豆ai换脸| 成人爽a毛片免费啪啪动漫| 成人欧美在线观看| 亚洲激情中文1区| 久久视频社区| www.激情网| 亚洲国产高潮在线观看| 亚洲欧洲日本mm| 亚洲成人男人天堂| 青草成人免费视频| 国产欧美精品一区| 日韩av黄色| a级黄色片免费| 亚洲的天堂在线中文字幕| 狠狠爱综合网| av天在线观看| 5g国产欧美日韩视频| 五月婷婷激情综合网| 国产精品自拍区| 亚洲 中文字幕 日韩 无码| 中文国产成人精品久久一| 国产在线精品不卡| 9765激情中文在线| 免费h精品视频在线播放| 国产精品欧美久久久久无广告| 久久久久毛片| av网站大全免费| 亚洲日本中文字幕| 国产精品一区二区在线看| 九色porny视频在线观看| 亚洲一区三区| 日韩精品中文字| 国产成人综合网站| av美女在线观看| 国产资源第一页| 一区二区三区黄色| 久艹在线视频| 国产亚洲美女久久| 成人一级黄色片| 国产日韩中文在线中文字幕| www.精品在线| 成人做爰www免费看视频网站| 蜜桃视频在线观看播放| 好看的中文字幕在线播放| 欧美成人黑人猛交| 欧美精品中文字幕一区| 亚洲国产毛片aaaaa无费看| 欧美精品一二| 香蕉视频免费在线播放| 久久综合九色99| 国产精品一区免费在线| 三上悠亚av一区二区三区| 日本高清不卡在线| 9191成人精品久久| 高清国产午夜精品久久久久久| 人人精品亚洲| 男人的天堂在线视频免费观看| 日韩久久久久久久久久久久| 日本久久久久久| 日韩女优av电影| 欧美激情自拍偷拍| 国产精品永久| japanese色系久久精品| 日本中文字幕电影在线免费观看| 800av在线免费观看| 国产乱码精品一区二区三区亚洲人 | 在线观看视频污| 中文字幕欧美日韩一区二区| 午夜免费在线观看精品视频| 日本精品视频一区二区| 成人性生交大片| 欧美特黄一区| 在线观看视频一区二区三区 | 成人97在线观看视频| 色丁香久综合在线久综合在线观看| 国产福利一区在线| 天天久久综合| 成人av在线播放| 国产婷婷视频在线| 欧美xxxxx在线视频| 国产伦一区二区三区色一情| 欧美激情奇米色| 精品久久久久香蕉网| 亚洲视频一二三区| 国v精品久久久网| 99热这里只有成人精品国产| 日韩在线成人| 高清在线视频不卡| 伦理片一区二区三区| 中文字幕第80页| 国产一区一区三区| 国产成人一区二区三区免费看| 欧美极品少妇xxxxⅹ免费视频| 欧美成人精精品一区二区频| 午夜久久久影院| 久久久噜噜噜久久人人看| 男人的j进女人的j一区| 999视频精品| 国偷自产av一区二区三区| 日韩欧美精品一区二区三区| xxxxx日韩| 中文字幕在线视频观看| 色七七在线观看| 中文字幕成人一区| 成人影片在线播放| 国产色视频一区| 91国在线精品国内播放| 亚洲人成电影网站色xx| 69堂精品视频| 黑人巨大精品欧美一区二区三区| 欧美国产激情一区二区三区蜜月| 国产精品一区二区不卡| 天堂蜜桃一区二区三区| 亚洲婷婷免费| 欧美丝袜丝交足nylons172| 一区二区三区国产好| 成人1区2区| 91在线超碰| 国产又色又爽又黄刺激在线视频| 每日更新在线观看av| 91热爆在线观看| 导航艳情国产电影| 色琪琪原网站亚洲香蕉| 免费看污黄网站| 精品少妇无遮挡毛片| 91看片就是不一样| 国产av无码专区亚洲精品| av免费观看网| 国产婷婷一区二区三区| 91亚洲精品国产| 全黄性性激高免费视频| 国产精品videossex国产高清| 综合久久国产| 99久re热视频精品98| 日韩一级免费看| 六月婷婷激情综合| 波多野结衣与黑人| 777av视频| www黄色在线| 丁香视频免费观看| 波多野结衣av在线播放| 色视频在线观看免费| 97视频在线观看网站| 伊人影院在线视频|