沒有日期字段就用其他的分區(qū)方式。
專業(yè)從事成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè),高端網(wǎng)站制作設(shè)計,微信小程序開發(fā),網(wǎng)站推廣的成都做網(wǎng)站的公司。優(yōu)秀技術(shù)團(tuán)隊竭力真誠服務(wù),采用H5頁面制作+CSS3前端渲染技術(shù),響應(yīng)式網(wǎng)站建設(shè),讓網(wǎng)站在手機(jī)、平板、PC、微信下都能呈現(xiàn)。建站過程建立專項小組,與您實時在線互動,隨時提供解決方案,暢聊想法和感受。
我們用日期分區(qū)主要是把每月的數(shù)據(jù)放在一個分區(qū),那么如果沒有分區(qū)字段,那么我們就需要用其他的字段分區(qū)了,比如hash分區(qū)(這個是自動分區(qū),直接將table分成若干個區(qū)域,數(shù)據(jù)會根據(jù)字段hash值自動分配到某個區(qū)域),列表分區(qū)(根據(jù)表中的某個字段去進(jìn)行分區(qū),比如某城有四個區(qū)域,那么正好用這四個值去分區(qū)就可以了)。
如果有其他的數(shù)字字段,那么看看這些數(shù)字字段能不能用,如果能用也可以用范圍分區(qū),不一定非要是日期字段的。
range分區(qū)使用的就是比較大小,理解正確,注意是less
than方式。
過程:把分區(qū)按值范圍從小到大排序,然后對要操作的值開始和第一個分區(qū)比較,先比較第一個字段,符合后直接放入第一個分區(qū),不符合條件后再比較第二個字段,符合后放入第一個分區(qū),不符合則依次和第二個分區(qū)比較。
(50,
任意值)第一個比較50
less
than
51符合,不進(jìn)行第二個比較,存放在p1區(qū);
(51,205)第一個比較不符合,進(jìn)行第二個比較也不符合;和第二個分區(qū)比較,第一個條件不符合,第二個比較205
less
then
301符合,放入第二個分區(qū)p2;
依次類推。
list分區(qū)也需要指定列的值,其分區(qū)值必須明確指定,該分區(qū)列只能有一個,不能像range或者h(yuǎn)ash分區(qū)那樣同時指定多個列做為分區(qū)依賴列,但它的單個分區(qū)對應(yīng)值可以是多個。
在分區(qū)時必須確定分區(qū)列可能存在的值,一旦插入的列值不在分區(qū)范圍內(nèi),則插入/更新就會失敗,因此通常建議使用list分區(qū)時,要創(chuàng)建一個default分區(qū)存儲那些不在指定范圍內(nèi)的記錄,類似range分區(qū)中的maxvalue分區(qū)。
在根據(jù)某字段,如城市代碼分區(qū)時,可以指定default,把非分區(qū)規(guī)則的數(shù)據(jù),全部放到這個default分區(qū)。
如:
create
table
custaddr
(
id
varchar2(15
byte)
not
null,
areacode
varchar2(4
byte)
)
partition
by
list
(areacode)
(
partition
t_list025
values
('025'),
partition
t_list372
values
('372')
,
partition
t_list510
values
('510'),
partition
p_other
values
(default)
)
最近有業(yè)務(wù)場景需要用多個字段做分區(qū)表,數(shù)據(jù)量比較大,保存時間也較長,經(jīng)過學(xué)習(xí)與實踐,算是基本完成,以下內(nèi)容為實踐樣例:
---建表語句
create table t_table
(
areacode varchar2(10),
appdate date,
text varchar(10)
)
partition by range(appdate)--根據(jù)字段 appdate 創(chuàng)建主分區(qū)
interval(numtoyminterval(1,'MONTH')) --主分區(qū)按 月 自動創(chuàng)建分區(qū)
subpartition by list(areacode) --再按 地區(qū) 創(chuàng)建子分區(qū)
subpartition template( --指定明確的子分區(qū)信息
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分區(qū),之后的自動分區(qū)
)
---模擬寫入測試數(shù)據(jù)
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');
--查詢數(shù)據(jù)
select * from t_table;
--查詢主分區(qū)數(shù)據(jù)
select *from t_table partition (mainpartition1);
--查詢子分區(qū)數(shù)據(jù)
select *from t_table subpartition (mainpartition1_sub1);
--查看自動創(chuàng)建的主分區(qū)
select * from user_tab_partitions where table_name='T_TABLE'
根據(jù)數(shù)據(jù)表字段值的范圍進(jìn)行分區(qū)。
創(chuàng)建完分區(qū)表后向表中添加一些數(shù)據(jù),declarenamevarchar2(10)。fractionnumber(5)。gradenumber(5)。inumber(8):=1。begin。foriin1。100000LOOP。當(dāng)我們的查詢語句不指定分區(qū)的時候,如果分區(qū)字段出現(xiàn)在where條件之后,Oracle會自動根據(jù)字段值的范圍掃描響應(yīng)的分區(qū)。
一般語法:
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
);