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也很快,这背后的实现技术是通过向表添加隐藏列实现的。具体情况之前写过一篇博客: http://blog.itpub.net/31480688/viewspace-2153741/ 这个问题是一个未公布的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问题
来源:这里教程网
时间:2026-03-03 12:58:24
作者:
编辑推荐:
下一篇:
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- Oracle的SCN显示问题
Oracle的SCN显示问题
26-03-03 - WRH$_ACTIVE_SESSION_HISTORY未自动清理导致SYSAUX空间过度增长的处理方法
- Debian监控业务指标配置(手把手教你用Prometheus+Grafana搭建Debian系统性能监控平台)
- 【kingsql分享】Oracle跨版本迁移之XTTS_V4版本的实施
【kingsql分享】Oracle跨版本迁移之XTTS_V4版本的实施
26-03-03 - PLSQL Developer 提示字段名,回车后卡顿解决
PLSQL Developer 提示字段名,回车后卡顿解决
26-03-03 - oracle 正则表达式4个主要函数
oracle 正则表达式4个主要函数
26-03-03 - 数据泵:expdp/impdp
数据泵:expdp/impdp
26-03-03 - 用listagg函数分组实现列转行
用listagg函数分组实现列转行
26-03-03 - Debian网络身份认证详解(手把手教你配置Debian系统下的企业级WiFi与有线网络身份验证)
- Oracle Exadata 存储服务器原理探究
Oracle Exadata 存储服务器原理探究
26-03-03
