您好,登錄后才能下訂單哦!
這篇文章主要介紹“怎么解決Oracle ORA-14148問題”,在日常操作中,相信很多人在怎么解決Oracle ORA-14148問題問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”怎么解決Oracle ORA-14148問題”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
Oracle12.1的庫里一張表上存在一個隱藏列,需要把它刪掉。隱藏列可以通過sys.dba_tab_cols查看。
使用下面的命令
alter table A drop unused columns;
alter table A drop column "SYS_NC00027$";
以上語法都沒有能把列刪掉。第一條沒有任何報錯,第二條報錯如下:
ORA-14148: DML and DDL operations are not directly allowed on the guard-column.
這個隱藏列的產生,其實是因為Oracle12c的一個新特性。12c之前,在向表添加帶有默認值的列的時候,如果不想影響生產,那么需要default+not null,這種方式只會去修改數據字典,速度很快,否則會實際的物理更新每一行,速度很慢,影響生產業務。12c以后,添加default值的列不加not null也很快,這背后的實現技術是通過向表添加隱藏列實現的。
這個問題是一個未公布的bug,Bug 18506065。解決方法如下:
1.安裝 Patch 18506065
2.升級到Bug 18506065被修復的12.2
3.臨時workaround:
alter system set "_add_col_optim_enabled"=false;
隱含參數含義:
SQL> select a.ksppinm name,b.ksppstvl value,a.ksppdesc description
2 from x$ksppi a,x$ksppcv b
3 where a.inst_id = USERENV ('Instance')
4 and b.inst_id = USERENV ('Instance')
5 and a.indx = b.indx
6 and upper(a.ksppinm) LIKE upper('%add_col_optim_enabled%')
7 order by name;
NAME
--------------------------------------------------------------------------------
VALUE
--------------------------------------------------------------------------------
DESCRIPTION
--------------------------------------------------------------------------------
_add_col_optim_enabled
TRUE
Allows new add column optimization
此外,數據泵導出加參數version=10.2,導入的時候也可能會報這個錯,也可以先修改_add_col_optim_enabled為false,導完之后再修改回來。
到此,關于“怎么解決Oracle ORA-14148問題”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。