Oracle设置和删除不可用列


以一
以一 2024-01-10 23:45:52 52483 赞同 0 反对 0
分类: 资源 标签: 运维
Oracle设置和删除不可用列 1、不可用列是什么? 就是表中的1个或多个列被ALTER TABLE…SET UNUSED 语句设置为无法再被程序利用的列。 2、使用场景?

Oracle设置和删除不可用列

1、不可用列是什么?

就是表中的1个或多个列被ALTER TABLE…SET UNUSED 语句设置为无法再被程序利用的列。

2、使用场景?

 

如果你担心从一个大表中删除一列可能花费大量时间,你可以使用ALTER TABLE…SET UNUSED语句。

如果你有这个需求,要删除某一个读写频繁的大表上的某些列,

如果你在业务繁忙时间直接执行 ALTER TABLE ABC DROP (COLUMN);

可能会收到 ORA-01562 – failed to extend rollback segment number string,

这是因为在这个删除列的过程中你可能会可能消耗掉整个回滚表空间,造成这样的错误出现。

3、使用理由(原理和优势)?

3.1 设置不可用列

该语句可将一个或多个列标识为不可用,但实际上并不是移除了列数据或回收了这些列占用的空间。

一个不可用列不会在查询或数据字典视图中显示, 其列名被删除以至于新增的列可以重用其列名。

在多数情况下,列上的约束,索引,和统计信息也被移除。

例外情况是被标识为不可用的LOB列的内部索引不会被移除。

3.2 删除不可用列

ALTER TABLE…DROP UNUSED COLUMNS 语句仅针对不可用列,用于正式删除被标识为不可用的列(物理上删除列同时回收被占用的空间)。

在接下来的ALTER TABLE语句中个,指定了可选条件 CHECKPOINT。

这个条件将在处理过程达到指定行数时触发一个检查点,此处为250. 检查点削减了在删除列操作中累积的undo logs的数量,从而避免潜在的undo空间耗尽。

ALTER TABLE hr.admin_emp DROP UNUSED COLUMNS CHECKPOINT 250;

4、使用限制?

无法删除属于 SYS 的表中的列

5、语法结构?

ALTER TABLE…SET UNUSED(C1,C2..)

ALTER TABLE…DROP UNUSED COLUMNS

例如:

ALTER TABLE hr.admin_emp SET UNUSED (hiredate, mgr);

ALTER TABLE hr.admin_emp DROP UNUSED COLUMNS;

5、数据字典

USER_UNUSED_COL_TABS

ALL_UNUSED_COL_TABS

DBA_UNUSED_COL_TABS

SELECT * FROM DBA_UNUSED_COL_TABS;

OWNER TABLE_NAME COUNT

————————— ————————— —–

HR ADMIN_EMP 2–count列代表不可用列数量

 

 

https://blog.csdn.net/weixin_42298105/article/details/116336976

如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!

评价 0 条
以一L0
粉丝 0 资源 1143 + 关注 私信
最近热门资源
银河麒麟桌面操作系统备份用户数据  127
统信桌面专业版【全盘安装UOS系统】介绍  122
银河麒麟桌面操作系统安装佳能打印机驱动方法  114
银河麒麟桌面操作系统 V10-SP1用户密码修改  105
最近下载排行榜
银河麒麟桌面操作系统备份用户数据 0
统信桌面专业版【全盘安装UOS系统】介绍 0
银河麒麟桌面操作系统安装佳能打印机驱动方法 0
银河麒麟桌面操作系统 V10-SP1用户密码修改 0
作者收入月榜
1

prtyaa 收益393.62元

2

zlj141319 收益218元

3

1843880570 收益214.2元

4

IT-feng 收益209.03元

5

风晓 收益208.24元

6

777 收益172.71元

7

Fhawking 收益106.6元

8

信创来了 收益105.84元

9

克里斯蒂亚诺诺 收益91.08元

10

技术-小陈 收益79.5元

请使用微信扫码

加入交流群

请使用微信扫一扫!