[20130513]Interval Partition的一些問題.txt
[20130513]Interval Partition的一些問題.txt
Interval Partition管理是11G的新特性,簡單了分割槽管理,本文簡單探討維護時遇到的問題.
1.建立測試環境:
SQL> @ver
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
CREATE TABLE t
(
id number,
create_date date
)
partition by range(create_date) interval(numtoyminterval(1,'MONTH'))
(
partition p201303 values less than (date '2013-03-01'),
partition p201304 values less than (date '2013-04-01'),
partition p201305 values less than (date '2013-05-01')
);
--可以發現interval=NO.
2.插入資料看看.
--可以發現建立一個新的分割槽. HIGH_VALUE=TO_DATE(' 2013-06-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN').
3.刪除分割槽:
--最後一個分割槽要刪除如何處理呢?
4.簡單一點是執行如下,先刪除interval特性再建立:
alter table t set interval ();
然後在執行.
alter table t set interval (NUMTOYMINTERVAL(1,'month'));
自己測試一下,實際上執行如下:
--這樣就可以很好的解決這個問題.
Interval Partition管理是11G的新特性,簡單了分割槽管理,本文簡單探討維護時遇到的問題.
1.建立測試環境:
export NLS_DATE_FORMAT='YYYY-MM-DD HH24:MI:SS'
SQL> @ver
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production
CREATE TABLE t
(
id number,
create_date date
)
partition by range(create_date) interval(numtoyminterval(1,'MONTH'))
(
partition p201303 values less than (date '2013-03-01'),
partition p201304 values less than (date '2013-04-01'),
partition p201305 values less than (date '2013-05-01')
);
SQL> column high_value format a85
SQL> select partition_name, interval, high_value from dba_tab_partitions where table_owner=user and table_name = 'T' order by partition_position;
PARTITION_NAME INT HIGH_VALUE
------------------------------ --- -------------------------------------------------------------------------------------
P201303 NO TO_DATE(' 2013-03-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
P201304 NO TO_DATE(' 2013-04-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
P201305 NO TO_DATE(' 2013-05-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
--可以發現interval=NO.
2.插入資料看看.
insert into t values(1 ,date'2013-05-11');
commit;
SQL> select partition_name, interval, high_value from dba_tab_partitions where table_owner=user and table_name = 'T' order by partition_position;
PARTITION_NAME INT HIGH_VALUE
------------------------------ --- -------------------------------------------------------------------------------------
P201303 NO TO_DATE(' 2013-03-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
P201304 NO TO_DATE(' 2013-04-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
P201305 NO TO_DATE(' 2013-05-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
SYS_P3209 YES TO_DATE(' 2013-06-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
--可以發現建立一個新的分割槽. HIGH_VALUE=TO_DATE(' 2013-06-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN').
3.刪除分割槽:
SQL> alter table t drop partition P201304;
Table altered.
SQL> alter table t drop partition P201305;
alter table t drop partition P201305
*
ERROR at line 1:
ORA-14758: Last partition in the range section cannot be dropped
--最後一個分割槽要刪除如何處理呢?
4.簡單一點是執行如下,先刪除interval特性再建立:
alter table t set interval ();
然後在執行.
alter table t set interval (NUMTOYMINTERVAL(1,'month'));
自己測試一下,實際上執行如下:
alter table t set interval (NUMTOYMINTERVAL(1,'month'));
SQL> alter table t set interval (NUMTOYMINTERVAL(1,'month'));
Table altered.
SQL> select partition_name, interval, high_value from dba_tab_partitions where table_owner=user and table_name = 'T' order by partition_position;
PARTITION_NAME INT HIGH_VALUE
------------------------------ --- -------------------------------------------------------------------------------------
P201303 NO TO_DATE(' 2013-03-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
P201305 NO TO_DATE(' 2013-05-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
SYS_P3209 NO TO_DATE(' 2013-06-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')
SQL> alter table t drop partition P201305;
Table altered.
--這樣就可以很好的解決這個問題.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/267265/viewspace-760897/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Interval Partition table 11G
- 3-Partition 問題
- 定期truncate 歷史間隔分割槽INTERVAL PARTITION
- Oracle Interval Partition 自動分割槽表-實驗Oracle
- 11g分割槽新特性之interval partition
- 關於partition table import的問題Import
- Partition管理問題集錦
- Oracle查詢Interval partition分割槽表內資料Oracle
- 關於Partition列被更新的問題
- Oracle Interval Partition 預設分割槽重新命名-指令碼Oracle指令碼
- Oracle OCP 1Z0 053 Q224(Interval Partition)Oracle
- split partition的一些測試
- exchange partition的一些測試
- interval partition自動新增分割槽引起的shared pool 4031錯誤
- 記次10g exchange partition很慢的問題
- exchange partition 交換的問題ORA-14130:
- 新建partition出現 device busy問題處理dev
- 關於分割槽表中的全partition掃描問題
- Oracle Interval Partition 生產環境-建立表FACT_STORAGE_SHEET為分割槽的過程Oracle
- xcode 的一些問題XCode
- postgresql copy UNICODE txt 問題。SQLUnicode
- 一些SQL問題SQL
- WKWebView的一些問題彙總WebView
- 記錄redis的一些問題Redis
- 關於Redis的一些小問題Redis
- JavaScript 中的一些奇怪問題JavaScript
- 面試中遇到的一些問題面試
- JAVA的一些基本問題(轉)Java
- web開發的一些問題Web
- 小程式遇到的一些問題
- 基礎揹包問題的一些題目!!
- 一些小問題彙總
- java 讀取.txt檔案時,注意的問題Java
- EditText選擇模式的一些問題模式
- vuejs整合echarts的一些問題VueJSEcharts
- Docker遇到的一些問題和感想Docker
- process/session/connection的一些問題Session
- 基環樹的一些基本問題