если мы используем оператор ALTER TABLE RENAME PARTITION для переименования существующих разделов в таблице Oracle, нужно ли нам воссоздавать локальные многораздельные индексы с недавно измененными именами разделов?
Переименование разделов в ORACLE
comment
Сообщите мне, если я не предоставил достаточно подробностей в вопросе.
- person Venkataramesh Kommoju   schedule 30.12.2009
Ответы (2)
Нет, переименование разделов не влияет на локально секционированные индексы. Вы можете легко проверить это:
--create table
CREATE TABLE t (
c1 DATE,
c2 NUMBER(3))
partition by range (c1) (
partition t_nov values less than (
to_date('01-12-2009 00:00:00', 'DD-MM-YYYY HH24:MI:SS')
),
partition t_dec values less than (
to_date('01-01-2010 00:00:00', 'DD-MM-YYYY HH24:MI:SS')
)
)
/
--create index
create index idx_t on t (c1) local (partition t_nov, partition t_dec);
--insert some rows
insert into t values (sysdate, 1);
insert into t values (sysdate, 1);
insert into t values (sysdate, 1);
insert into t values (sysdate, 1);
insert into t values (sysdate, 1);
insert into t values (sysdate, 1);
insert into t values (sysdate, 1);
insert into t values (sysdate, 1);
insert into t values (sysdate, 1);
insert into t values (sysdate, 1);
--gather statistics
exec dbms_stats.gather_table_stats('SYSTEM', 'T');
--set autotrace on, to determine that index is used
set autotrace on
--select indexed column
select c1 from t where c1 < sysdate+1;
--------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time | Pstart| Pstop |
--------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 11 | 88 | 1 (0)| 00:00:01 | | |
| 1 | PARTITION RANGE ITERATOR| | 11 | 88 | 1 (0)| 00:00:01 | 1 | KEY |
|* 2 | INDEX RANGE SCAN | IDX_T | 11 | 88 | 1 (0)| 00:00:01 | 1 | KEY |
--------------------------------------------------------------------------------------------------
--rename partition
alter table t rename partition t_dec to t_december;
Table altered.
select c1 from t where c1 < sysdate+1;
--------------------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time | Pstart| Pstop |
--------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 11 | 88 | 1 (0)| 00:00:01 | | |
| 1 | PARTITION RANGE ITERATOR| | 11 | 88 | 1 (0)| 00:00:01 | 1 | KEY |
|* 2 | INDEX RANGE SCAN | IDX_T | 11 | 88 | 1 (0)| 00:00:01 | 1 | KEY |
--------------------------------------------------------------------------------------------------
Индекс все еще используется после переименования раздела
person
Thomas Aregger
schedule
30.12.2009
Спасибо за великолепную демонстрацию. Цени свое время.
- person Venkataramesh Kommoju; 30.12.2009
Переименование секций не влияет на локально секционированные индексы, поэтому вам не нужно будет перестраивать индексы.
person
Bob Jarvis - Reinstate Monica
schedule
30.12.2009