Partition Tabel测试drop和truncate 分区对全局和本地索引是否有影响
来源:互联网 发布:小痰盂和饼干头 知乎 编辑:程序博客网 时间:2024/06/04 19:58
创建分区表:
create table test10
(sal_date date not null,
sal_id number not null,
sal_row number(12) not null
)
partition by range(sal_date)
(partition p_1 values less than(to_date(‘2010-01-01’,’yyyy-mm-dd’)),
partition p_2 values less than(to_date(‘2011-01-01’,’yyyy-mm-dd’)),
partition p_3 values less than(to_date(‘2012-01-01’,’yyyy-mm-dd’)),
partition p_4 values less than(to_date(‘2013-01-01’,’yyyy-mm-dd’)),
partition p_5 values less than(to_date(‘2014-01-01’,’yyyy-mm-dd’)),
partition p_6 values less than(to_date(‘2015-01-01’,’yyyy-mm-dd’)),
partition p_7 values less than(to_date(‘2016-01-01’,’yyyy-mm-dd’)),
partition p_8 values less than(to_date(‘2017-01-01’,’yyyy-mm-dd’)),
partition p_9 values less than(to_date(‘2018-01-01’,’yyyy-mm-dd’)),
partition p_10 values less than(to_date(‘2019-01-01’,’yyyy-mm-dd’)),
partition p_11 values less than(to_date(‘2020-01-01’,’yyyy-mm-dd’)),
partition p_12 values less than(to_date(‘2021-01-01’,’yyyy-mm-dd’)),
partition p_13 values less than(to_date(‘2022-01-01’,’yyyy-mm-dd’)),
partition p_14 values less than(to_date(‘2023-01-01’,’yyyy-mm-dd’)),
partition p_15 values less than(maxvalue)
)
插入数据:
insert into test10 SELECT TRUNC(SYSDATE)-ROWNUM, dbms_random.random,ROWNUM FROM dual CONNECT BY LEVEL<=5000;
创建全局索引:
create index test10_sal_id on test10(sal_id) global;
创建本地索引:
create index test10_sal_date on test10(sal_date) local;
查询分区表索引状态,均有效:
SQL> select index_name,status from dba_indexes where table_name=’TEST10’;
INDEX_NAME STATUS
TEST10_SAL_DATE N/A
TEST10_SAL_ID VALID
删除test10的一个p_2分区:
SQL> alter table test10 truncate partition p_2;
Table truncated.
再次查询索引状态 Golbal索引已经失效了而local索引没有影响:
SQL> select index_name,status from dba_indexes where table_name=’TEST10’;
INDEX_NAME STATUS
TEST10_SAL_DATE N/A
TEST10_SAL_ID UNUSABLE
分区进行drop的时候:
SQL> alter table test10 drop partition p_3;
Table altered.
全局索引也会失效:
SQL> select index_name,status from dba_indexes where table_name=’TEST10’;
INDEX_NAME STATUS
TEST10_SAL_DATE N/A
TEST10_SAL_ID UNUSABLE
如下是避免由于分区表进行truncate和drop操作时发生global索引失效:
SQL> alter table test10 truncate partition p_5 update global indexes;
Table truncated.
全局索引没有失效:
SQL> select index_name,status from dba_indexes where table_name=’TEST10’;
INDEX_NAME STATUS
TEST10_SAL_DATE N/A
TEST10_SAL_ID VALID
drop分区表的时候全局索引也没有失效:
SQL> alter table test10 drop partition p_6 update global indexes;
Table altered.
SQL> select index_name,status from dba_indexes where table_name=’TEST10’;
INDEX_NAME STATUS
TEST10_SAL_DATE N/A
TEST10_SAL_ID VALID
总结:1:local index在truncate和drop Partition table的时候不会失效
2:global index在truncate和drop Partition table的时候加上update global indexes则global index会自动更新,否则会失效需要rebuild
- Partition Tabel测试drop和truncate 分区对全局和本地索引是否有影响
- Oracle分区表drop和truncate partition索引失效问题
- Oracle分区表drop和truncate partition索引失效问题
- 全局分区索引和本地索引示例
- Oracle12c中性能优化&功能增强新特性之全局索引DROP和TRUNCATE 分区的异步维护
- Oracle12c中性能优化&功能增强新特性之全局索引DROP和TRUNCATE 分区的异步维护
- 分区truncate操作的介绍及对全局索引和空间释放影响的案例解析
- 分区索引--本地索引和全局索引比较
- 分区索引--本地索引和全局索引比较
- Oracle分区索引-本地索引和全局索引比较
- Oracle分区索引--本地索引和全局索引比较
- 分区索引--本地索引和全局索引比较
- 分区索引--本地索引和全局索引比较
- 索引分区(本地索引和全局索引)
- Oracle分区索引--本地索引和全局索引比较
- Oracle分区索引--本地索引和全局索引比较
- 分区索引和全局索引
- phoenix全局索引和本地索引测试,和hive连接
- 权 限 linux
- KRONOS查看设备信息
- 生成条形码_jQuery_barcode
- PHP开发安全问题总结
- 控制台API
- Partition Tabel测试drop和truncate 分区对全局和本地索引是否有影响
- Hibernate 一对多外键单向关联
- Firefox常用web开发插件
- arm, arm64, i386, x86_64
- CGContextRef使用简要教程
- Eclipse中设置作者日期等信息
- Another MySQL daemon already running with the same unix socket
- 【Android】读取sdcard卡上的所有图片并且显示,读取的过程有进度条显示
- Javascript事件模拟