mysql global index_Oracle中addsplit partition对globallocal index的影响
生產(chǎn)庫中某些大表的分區(qū)異常,需要對現(xiàn)有表進(jìn)行在線操作,以添加丟失分區(qū),因?yàn)槭巧a(chǎn)庫,還是謹(jǐn)慎點(diǎn)好,今天有空,針對addspli
生產(chǎn)庫中某些大表的分區(qū)異常,需要對現(xiàn)有表進(jìn)行在線操作,以添加丟失分區(qū),因?yàn)槭巧a(chǎn)庫,還是謹(jǐn)慎點(diǎn)好,今天有空,針對add&split分區(qū)對global&local索引的影響進(jìn)行了測試,測試版本為Oracle11.2.0.4,過程如下:
首先,創(chuàng)建分區(qū)表:
CREATE TABLE TP1
(
C1 INT PRIMARY KEY,
C2 VARCHAR2(10),
C3 CHAR(10)
)
partition by range (c1)
(
partition p1 values less than(6),
partition p2 values less than(11),
partition p3 values less than(16),
partition maxvalue values less than(maxvalue));
但在add partition時(shí)遇到了問題,報(bào)錯(cuò)如下:
ORA-14074: 分區(qū)界限必須調(diào)整為高于最后一個(gè)分區(qū)界限
根本原因是存在最后maxvalue分區(qū),于是,再創(chuàng)建一個(gè)不帶maxvalue的分區(qū)表:
CREATE TABLE TP2
(
C1 INT PRIMARY KEY,
C2 VARCHAR2(10),
C3 CHAR(10)
)
partition by range (c1)
(
partition p1 values less than(6),
partition p2 values less than(11),
partition p3 values less than(16));
然后,,創(chuàng)建local索引:
create index idx_tp2_c2 on tp2(c2) local;
因?yàn)橹麈I就是個(gè)global索引,所以,不需要另外創(chuàng)建global index,我們insert數(shù)據(jù):
insert into tp2 vlaues(1,'aaa','aaa');
insert into tp2 vlaues(2,'aaa','aaa');
insert into tp2 vlaues(3,'aaa','aaa');
insert into tp2 vlaues(4,'aaa','aaa');
insert into tp2 vlaues(5,'aaa','aaa');
insert into tp2 vlaues(6,'aaa','aaa');
insert into tp2 vlaues(7,'aaa','aaa');
insert into tp2 vlaues(8,'aaa','aaa');
insert into tp2 vlaues(9,'aaa','aaa');
insert into tp2 vlaues(10,'aaa','aaa');
commit;
我們add partition:
ALTER TABLE tp2 add PARTITION p10 values less than(51);
add partition成功,因?yàn)椴淮嬖趍axvalue分區(qū),而且,add partition對global和local索引均無影響;
那么,split partition:
ALTER TABLE tp2 SPLIT PARTITION p2 AT (8) INTO (PARTITION p2, PARTITION p22) ;
發(fā)現(xiàn)split分區(qū)會(huì)導(dǎo)致golbal索引失效,而local索引正常,為split分區(qū)命令添加update indexes選項(xiàng)后,再split分區(qū)對global&local索引均無影響:
ALTER TABLE tp2 SPLIT PARTITION p1 AT (3) INTO (PARTITION p1, PARTITION p11) update indexes;
以上為測試結(jié)果,記錄于此,以便今后其他同學(xué)和自己參考。
本文永久更新鏈接地址:
本文原創(chuàng)發(fā)布php中文網(wǎng),轉(zhuǎn)載請注明出處,感謝您的尊重!
總結(jié)
以上是生活随笔為你收集整理的mysql global index_Oracle中addsplit partition对globallocal index的影响的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ubuntu终端命令停止_从命令行关闭L
- 下一篇: mysql+after+commit_S