一、什么場景、時間適合用分區表?
創新互聯公司是一家以網絡技術公司,為中小企業提供網站維護、成都網站建設、成都做網站、網站備案、服務器租用、域名申請、軟件開發、小程序開發等企業互聯網相關業務,是一家有著豐富的互聯網運營推廣經驗的科技公司,有著多年的網站建站經驗,致力于幫助中小企業在互聯網讓打出自已的品牌和口碑,讓企業在互聯網上打開一個面向全國乃至全球的業務窗口:建站聯系熱線:028-86922220
1、大數據量的表,比如大于2GB。一方面2GB文件對于32位OS是一個上限,另外備份時間長。
2、包括歷史數據的表,比如最新的數據放入到最新的分區中。典型的例子:歷史表,只有當前月份的數據可以被修改,而其他月份只能read-only
就我實際工作中了解到的幾種情況:
全國法人單位名錄庫約有700-800萬條記錄,字段約有100個。可按所屬省行政區劃、指標枚舉等字段建立分區表。
北京統計宏觀數據庫,在村一級采用一維表存儲,隨著指標增多,記錄可達千萬至億條級。
上海市房管局系統的權屬數據,按照市中心及19個區縣,共劃分了20個分區,以期提高數據的存取效率。
二、分區表有什么優勢?
1、增強可用性:如果表的某個分區出現故障,表在其他分區的數據仍然可用;
2、維護方便:如果表的某個分區出現故障,需要修復數據,只修復該分區即可;
3、均衡I/O:可以把不同的分區映射到磁盤以平衡I/O,改善整個系統性能;
4、改善查詢性能:對分區對象的查詢可以僅搜索自己關心的分區,提高檢索速度。
一.表分區策略
1.識別大表
采用ANALYZE TABLE語句進行分析,然后查詢數據字典獲得相應的數據量。
2.大表如何分區
可根據月份,季度以及年份等進行分區;
3.分區的表空間規劃
要對每個表空間的大小進行估計
二.創建表分區
a.創建范圍分區的關鍵字是'RANGE'
1.范圍分區
create table ware_retail_part --創建一個描述商品零售的數據表
(
id integer primary key,--銷售編號
retail_date date,--銷售日期
ware_name varchar2(50)--商品名稱
)
partition by range(retail_date)
(
--2011年第一個季度為part_01分區
partition par_01 values less than(to_date('2011-04-01','yyyy-mm-dd')) tablespace TEMP01,
--2011年第二個季度為part_02分區
partition par_02 values less than(to_date('2011-07-01','yyyy-mm-dd')) tablespace TEMP01,
--2011年第三個季度為part_03分區
partition par_03 values less than(to_date('2011-10-01','yyyy-mm-dd')) tablespace TEMP01,
--2011年第四個季度為part_04分區
partition par_04 values less than(to_date('2012-01-01','yyyy-mm-dd')) tablespace TEMP01
);
2.創建散列分區
3.組合分區:
4.interval 分區
三.創建索引分區
索引分區分為本地索引分區和全局索引分區,全局索引不反應基礎表的結構,要分區只能進行范圍分區。
創建索引分區要參照表分區
四.分區技術簡介
優點:
1.減少維護工作量
2.增強數據的可用性
3.均衡I/O,提升性能
4.提高查詢速度
5.分區對用戶保持透明,用戶感覺不到分區的存在。
五,管理表分區
1.添加表分區
ALTER TABLE...ALTER PARATITION
2.合并表分區
3.刪除分區
ALTER TABLE...DROP PARTITION
刪除分區時,里面的數據也會被刪除。
-創建表和分區
create table sales--創建一個銷售記錄表
(
id number primary key,--記錄編號
goodsname varchar2(10),--商品名
saledate date--銷售日期
)
partition by range(saledate)--按照日期分區
(
--第一季度數據
partition part_sea1 values less than(to_date('2011-04-01','yyyy-mm-dd')) tablespace tbsp_1,
--第二季度數據
partition part_sea2 values less than(to_date('2011-07-01','yyyy-mm-dd')) tablespace tbsp_2,
--第三季度數據
partition part_sea3 values less than(to_date('2011-10-01','yyyy-mm-dd')) tablespace tbsp_1,
--第四季度數據
partition part_sea4 values less than(to_date('2012-01-01','yyyy-mm-dd')) tablespace tbsp_2
);
--創建局部索引
create index index_3_4 on sales(saledate)
local(
partition part_seal tablespace tbsp_1,
partition part_sea2 tablespace tbsp_2,
partition part_sea3 tablespace tbsp_1,
partition part_sea4 tablespace tbsp_2
);
--并入分區
alter table sales merge partitions part_sea3,part_sea4 into partition part_sea4;
--重建局部索引
alter table sales modify partition part_sea4 rebuild unusable local indexes;
六.管理索引分區
刪除索引:DROP PARTITION
重建分區:REBUILT PARTITION
更名索引分區:RENAME PARTITION
分割索引分區:SPLIT PARTITION
1、一般分區表都會很大,所以可以先創建表空間,為了讓分區表存放到單獨的表空間,否則默認會存放到USERS表空間
2、創建TABLESPACE TS1:
CREATE TABLESPACE TS1 DATAFILE '/data1/oracle/test.dbf' SIZE 512M AUTOEXTEND ON NEXT 512M MAXSIZE UNLIMITED;
3、創建分區表,需要確定按什么分區,比如按id或按時間段:
CREATE TABLE test_201602
(
ID NUMBER(10) NOT NULL,
CREATE_TIME DATE,
)
TABLESPACE TS1
PARTITION BY LIST (ID)
(PARTITION PT_1001 VALUES (1001) TABLESPACE TS1);
4、繼續增加分區
ALTER TABLE test_201602 ADD PARTITION "PT_1003" VALUES (1003) LOGGING NOCOMPRESS;
ALTER TABLE test_201602 ADD PARTITION "PT_1004" VALUES (1004) LOGGING NOCOMPRESS;
5、查詢表及分區數量
select TABLE_NAME,PARTITION_COUNT,DEF_TABLESPACE_NAME from USER_PART_TABLES order by DEF_TABLESPACE_NAME;
根據數據表字段值的范圍進行分區。
創建完分區表后向表中添加一些數據,declarenamevarchar2(10)。fractionnumber(5)。gradenumber(5)。inumber(8):=1。begin。foriin1。100000LOOP。當我們的查詢語句不指定分區的時候,如果分區字段出現在where條件之后,Oracle會自動根據字段值的范圍掃描響應的分區。
最近有業務場景需要用多個字段做分區表,數據量比較大,保存時間也較長,經過學習與實踐,算是基本完成,以下內容為實踐樣例:
---建表語句
create table t_table
(
areacode varchar2(10),
appdate date,
text varchar(10)
)
partition by range(appdate)--根據字段 appdate 創建主分區
interval(numtoyminterval(1,'MONTH')) --主分區按 月 自動創建分區
subpartition by list(areacode) --再按 地區 創建子分區
subpartition template( --指定明確的子分區信息
subpartition sub1 values('101'),
subpartition sub2 values('201'),
subpartition sub3 values('301')
)
(
partition mainpartition1 values less than(to_date('2019-04-01','yyyy-mm-dd'))--2019年4月1日前的放入mainpartition1分區,之后的自動分區
)
---模擬寫入測試數據
insert into t_table values('101',to_date('2019-03-03','yyyy-mm-dd'),'a');
insert into t_table values('101',to_date('2019-02-03','yyyy-mm-dd'),'a');
insert into t_table values('101',to_date('2019-04-03','yyyy-mm-dd'),'a');
insert into t_table values('201',to_date('2019-03-03','yyyy-mm-dd'),'a');
insert into t_table values('201',to_date('2019-05-03','yyyy-mm-dd'),'a');
insert into t_table values('301',to_date('2019-04-01','yyyy-mm-dd'),'a');
--查詢數據
select * from t_table;
--查詢主分區數據
select *from t_table partition (mainpartition1);
--查詢子分區數據
select *from t_table subpartition (mainpartition1_sub1);
--查看自動創建的主分區
select * from user_tab_partitions where table_name='T_TABLE'
一般語法:
create?table?t_test?(
pk_id?number(30)?not?null,
add_date_time??DATE,
constraintPK_T_TEST?primary?key?(pk_id)
)
PARTITION?BY?RANGE?(add_date_time)
(
PARTITIONt_test_2013_less?VALUES?LESS?THAN?(TO_DATE('2013-01-01?00:00:00','yyyy-mm-ddhh24:mi:ss'))?TABLESPACE?TS_MISPS,
PARTITIONt_test_2013?VALUES?LESS?THAN?(TO_DATE('2014-01-01?00:00:00','yyyy-mm-ddhh24:mi:ss'))?TABLESPACE?TS_MISPS,
PARTITION?t_test_2014VALUES?LESS?THAN?(TO_DATE('2015-01-01?00:00:00','yyyy-mm-dd?hh24:mi:ss'))TABLESPACE?TS_MISPS
);
網頁標題:oracle表分區怎么建,oracle表分區創建
分享網址:http://vcdvsql.cn/article14/heghge.html
成都網站建設公司_創新互聯,為您提供小程序開發、云服務器、建站公司、網站建設、、軟件開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯