广告
返回顶部
首页 > 资讯 > 数据库 >ORA-39726:unsupported add/drop column operation on compressed tables
  • 660
分享到

ORA-39726:unsupported add/drop column operation on compressed tables

2024-04-02 19:04:59 660人浏览 八月长安
摘要

ORA-39726:  unsupported add/drop column operation on compressed tables   问题现象 :

ORA-39726:

 unsupported add/drop column operation on compressed tables

 

问题现象 :

Basic compression 下,增加字段时不能指定default ,否则报错 ORA-39726

问题重现:
sql> conn chenjch/a

SQL> create table t1(id number(10) not null) compress;

SQL> insert into t1 values(1);

SQL> commit;

SQL> ALTER TABLE t1 ADD UPDATE_TIME DATE DEFAULT SYSDATE NOT NULL ;

ALTER TABLE t1 ADD UPDATE_TIME DATE DEFAULT SYSDATE NOT NULL

                   *

ERROR at line 1:

ORA-39726: unsupported add/drop column operation on compressed tables

问题原因 :

https://docs.oracle.com/cd/E11882_01/server.112/e25494/tables.htm#ADMIN11630

  ORA-39726:unsupported add/drop column operation on compressed tables 

解决方案:

SQL> SELECT table_name, compression, compress_for FROM user_tables where table_name='T1';

TABLE_NAME COMPRESS COMPRESS_FOR

---------- -------- ------------------------------

T1         ENABLED   BASIC

 

--- 去掉 default 后可以正常添加列,但是很多情况下业务逻辑是不允许的;

ALTER TABLE t1 ADD UPDATE_TIME DATE;

--- 将表压缩级别 basic 改成 oltp 后可以正常添加字段;
--- 对现有的数据不压缩,对以后产生的数据生效,数据量越大,速度越慢,测试 1 亿条数据,耗时 30 秒;

SQL> alter table t1 compress for oltp;    
---- 对现有的和以后的数据都生效,数据量越大,速度越慢,并且会产生排它,生产环境慎用;

sql> Alter table t1 move compress for oltp;  

SQL>  SELECT table_name, compression, compress_for FROM user_tables where table_name='T1';

TABLE_NAME COMPRESS COMPRESS_FOR

---------- -------- ------------------------------

T1         ENABLED   ADVANCED

 

SQL> ALTER TABLE t1 ADD UPDATE_TIME DATE DEFAULT SYSDATE NOT NULL ;

Table altered.

--- 字段添加成功后也可以在改回 basic;

SQL> alter table t1 compress;

Table altered.

 

SQL> SELECT table_name, compression, compress_for FROM user_tables where table_name='T1';

TABLE_NAME COMPRESS COMPRESS_FOR

---------- -------- ------------------------------

T1         ENABLED  BASIC

 

同理,删除字段也会有这个问题

SQL> ALTER TABLE t1 drop column  UPDATE_TIME;

ALTER TABLE t1 drop column  UPDATE_TIME

                            *

ERROR at line 1:

ORA-39726: unsupported add/drop column operation on compressed tables

SQL> ALTER TABLE t1 SET UNUSED COLUMN UPDATE_TIME;

Table altered.

SQL> ALTER TABLE t1 DROP UNUSED COLUMNS;

ALTER TABLE t1 DROP UNUSED COLUMNS

*

ERROR at line 1:

ORA-39726: unsupported add/drop column operation on compressed tables

 

SQL> alter table t1 compress for oltp;

Table altered.


SQL> ALTER TABLE t1 DROP UNUSED COLUMNS;

Table altered.

SQL> alter table t1 compress;

Table altered.

  欢迎关注我的微信公众号"IT小Chen",共同学习,共同成长!!!

ORA-39726:unsupported add/drop column operation on compressed tables

ORA-39726:unsupported add/drop column operation on compressed tables


 

 

 

 

您可能感兴趣的文档:

--结束END--

本文标题: ORA-39726:unsupported add/drop column operation on compressed tables

本文链接: https://www.lsjlt.com/news/49545.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作