今天有朋友問到如下一則案例,ORA-01114,ORA-27067以及OSD-04026錯誤同時出現:
*** ACTION NAME:() 2009-04-01 09:31:00.762
*** MODULE NAME:(JDBC Thin Client) 2009-04-01 09:31:00.762
*** SERVICE NAME:(SYS$USERS) 2009-04-01 09:31:00.762
*** SESSION ID:(145.9) 2009-04-01 09:31:00.762
*** 2009-04-01 09:31:00.762
ksedmp: internal or fatal error
ORA-01114: 將塊寫入檔案 201 時出現 IO 錯誤 (塊 # 492)
ORA-27067: I/O 緩衝區的大小無效
OSD-04026: Invalid parameter passed. (OS 1318912)
ORA-01114: 將塊寫入檔案 201 時出現 IO 錯誤 (塊 # 492)
ORA-27067: I/O 緩衝區的大小無效
OSD-04026: Invalid parameter passed. (OS 1318912)
ORA-01114: 將塊寫入檔案 201 時出現 IO 錯誤 (塊 # 492)
ORA-27067: I/O 緩衝區的大小無效
OSD-04026: Invalid parameter passed. (OS 1318912)
ORA-01114: 將塊寫入檔案 201 時出現 IO 錯誤 (塊 # 9)
ORA-27067: I/O 緩衝區的大小無效
OSD-04026: Invalid parameter passed. (OS 1318912)
No current SQL statement being executed.
這個錯誤在9i的某些版本中,是因為檔案大小超越了OS的限制時會出現的一個問題,多數出現在Windows平台上。
Metalink上的Notes:317174.1,記錄了一個類似的問題,這是Oracle Server - Enterprise Edition - Version: 9.2.0.1.0 Microsoft Windows (32-bit)上的一個Bug:
Its a Bug specific to NT platform only. Cannot AUTOEXTEND to 4Gb boundary,This bug is fixed in 9203.
317174.1 記錄的錯誤資訊如下:
ORA-283: recovery session canceled due to errors
ORA-1115: IO error reading block from file 11 (block # 204802)
ORA-1110: data file 11: 'E:ORACLEORA92BORGMAXIMO.ORA'
ORA-27069: skgfdisp: attempt to do I/O beyond the range of the file
OSD-4026: Invalid parameter passed. (OS-204802)
但是這個資料庫是64位Windows上的10.2.0.4,問題出現在暫存資料表空間檔案上。
查詢過幾個相關的問題原因都是類似的:CTAS處理大批量的資料導致異常。
這個問題的CTAS SQL有600多個Case When判斷,SQL文本有47K,強烈使用者建議改寫SQL。