一 分區(qū)表技術(shù)概述
成都創(chuàng)新互聯(lián)成都企業(yè)網(wǎng)站建設(shè)服務(wù),提供網(wǎng)站設(shè)計(jì)制作、做網(wǎng)站網(wǎng)站開(kāi)發(fā),網(wǎng)站定制,建網(wǎng)站,網(wǎng)站搭建,網(wǎng)站設(shè)計(jì),響應(yīng)式網(wǎng)站設(shè)計(jì),網(wǎng)頁(yè)設(shè)計(jì)師打造企業(yè)風(fēng)格網(wǎng)站,提供周到的售前咨詢和貼心的售后服務(wù)。歡迎咨詢做網(wǎng)站需要多少錢:13518219792
二 分區(qū)索引技術(shù)概述
⑴ 本地前綴分區(qū)索引
適用場(chǎng)景:
如果歷史數(shù)據(jù)整理非常頻繁、而且不能承受全局分區(qū)索引重建的長(zhǎng)時(shí)間帶來(lái)的索引不可用
同時(shí)、日常交易性能尚能接受、則建議設(shè)計(jì)為本地非前綴分區(qū)索引
注意:本地分區(qū)索引不能保證唯一性(除非分區(qū)鍵是約束的一部分)
缺點(diǎn):
主要體現(xiàn)在數(shù)據(jù)的高可用性方面
當(dāng)DROP分區(qū)后、全局分區(qū)索引則全部INVALID、除非REBULID
但數(shù)據(jù)量越大、重建索引的時(shí)間越長(zhǎng)
一般來(lái)講,如果需要將數(shù)據(jù)按照某個(gè)值邏輯聚集,多采用范圍分區(qū)。如基于時(shí)間數(shù)據(jù)的按“年”、“月”等分區(qū)就是很典型的例子。在許多情況下,范圍分區(qū)都能利用到分區(qū)消除特性( = = = between…and 等篩選條件下)。
如果在表里無(wú)法找到一個(gè)合適的屬性來(lái)按這個(gè)屬性完成范圍分區(qū),但你又想享受分區(qū)帶來(lái)的性能與可用性的提升,則可以考慮使用散列分區(qū)。(適合使用 = IN 等篩選條件)
如果數(shù)據(jù)中有一列或有一組離散值,且按這一列進(jìn)行分區(qū)很有意義,則這樣的數(shù)據(jù)就很適合采用列表分區(qū)。
如果某些數(shù)據(jù)邏輯上可以進(jìn)行范圍分區(qū),但是得到的范圍分區(qū)還是太大,不能有效管理,則可以考慮使用組合分區(qū)(范圍分區(qū)+hash 或范圍分區(qū)+列表分區(qū))。
create table products_table
(
id number(2),
name varchar2(50),
sale_date date
)
partition by range(sale_date)
interval (numtoyminterval(1,'month'))
(
partition p_month_1 values less than (to_date('2016-01-01','yyyy-mm-dd'))
)
如圖,取 products_table 中的 sale_date 列作為分區(qū)鍵創(chuàng)建按月自增分區(qū);
所有銷售時(shí)間在 ‘2016-01-01’之前的記錄都會(huì)被放入 p_month_1 分區(qū);
銷售時(shí)間在‘2016-01-01’之后的記錄在插入時(shí)Oracle會(huì)自動(dòng)創(chuàng)建記錄所屬月的分區(qū);
比如當(dāng)有銷售時(shí)間分別為 2016年1月20日 與 2016年2月20日 的兩條記錄插入時(shí),Oracle會(huì)分別創(chuàng)建一個(gè)上限值為 ‘2016-01-31’的分區(qū)和一個(gè)上限值為‘2016-02-29’的分區(qū)來(lái)存儲(chǔ)這兩條記錄
Oracle的表分區(qū)功能通過(guò)改善可管理性、性能和可用性,從而為各式應(yīng)用程序帶來(lái)了極大的好處,分區(qū)功能能夠?qū)⒈怼⑺饕蛩饕M織表進(jìn)一步細(xì)分為段,這些數(shù)據(jù)庫(kù)對(duì)象的段叫做分區(qū)。
范圍分區(qū)(RANGE)
范圍分區(qū)將數(shù)據(jù)基于范圍映射到每一個(gè)分區(qū),這個(gè)范圍是你在創(chuàng)建分區(qū)時(shí)指定的分區(qū)鍵決定的。這種分區(qū)方式是最為常用的,并且分區(qū)鍵經(jīng)常采用日期。當(dāng)使用范圍分區(qū)時(shí),請(qǐng)考慮以下幾個(gè)規(guī)則:
1)每一個(gè)分區(qū)都必須有一個(gè)VALUES LESS THEN子句,它指定了一個(gè)不包括在該分區(qū)中的上限值。分區(qū)鍵的任何值等于或者大于這個(gè)上限值的記錄都會(huì)被加入到下一個(gè)高一些的分區(qū)中。
2)所有分區(qū),除了第一個(gè),都會(huì)有一個(gè)隱式的下限值,這個(gè)值就是此分區(qū)的前一個(gè)分區(qū)的上限值。
3)在最高的分區(qū)中,MAXVALUE被定義。MAXVALUE代表了一個(gè)不確定的值。這個(gè)值高于其它分區(qū)中的任何分區(qū)鍵的值,也可以理解為高于任何分區(qū)中指定的VALUE LESS THEN的值,同時(shí)包括空值。
)本地分區(qū)索引
本地分區(qū)索引是使用了LOCAL屬性創(chuàng)建的分區(qū)索引,其特征是索引分區(qū)的所有鍵均指向其基表某個(gè) 唯一分區(qū)中存儲(chǔ)的相應(yīng)行。Oracle創(chuàng)建本地分區(qū)索引的目的就是要確保索引也是分區(qū)管理的,而且索引的分區(qū)與表的分區(qū)是均衡的,也就是本地分區(qū)索引具有與其基表相同的分區(qū)、子分區(qū),即分區(qū)鍵等同于表的分區(qū)鍵、分區(qū)數(shù)等同于表的分區(qū)數(shù)。
任何基表分區(qū)的增加、刪除、合并、分割操作,或者散列分區(qū)增加或合并操作,Oracle會(huì)通過(guò)其自身的機(jī)制自動(dòng)維護(hù)本地分區(qū)索引相應(yīng)的分區(qū),此即本地分區(qū)索引與基表的均衡性原則。
如果分區(qū)列能夠形成索引列的一個(gè)子集,則本地分區(qū)索引可以是唯一索引。該限制能確保具有相同索引鍵的行始終映射到同一個(gè)分區(qū),在該分區(qū)中,違反唯一性的行為能被檢測(cè)到。
當(dāng)表中的數(shù)據(jù)量不斷增大,查詢數(shù)據(jù)的速度就會(huì)變慢,應(yīng)用程序的性能就會(huì)下降,這時(shí)就應(yīng)該考慮對(duì)表進(jìn)行分區(qū)。表進(jìn)行分區(qū)后,邏輯上表仍然是一張完整的表,只是將表中的數(shù)據(jù)在物理上存放到多個(gè)表空間(物理文件上),這樣查詢數(shù)據(jù)時(shí),不至于每次都掃描整張表。
1、創(chuàng)建語(yǔ)句
create table p(id number)
partition by range(id)
(partition p1 values less than(100) tablespace t1,
partition p2 values less than(200) tablespace t2,
partition p3 values less than(300) tablespace t3);
2、添加分區(qū)
alter table p add partition p4 values less than (400) tablespace t4;
3、清除分區(qū)數(shù)據(jù)
alter table p trunc partition p1;
4、刪除分區(qū)
alter table p drop partition p1;
一.表分區(qū)策略
1.識(shí)別大表
采用ANALYZE TABLE語(yǔ)句進(jìn)行分析,然后查詢數(shù)據(jù)字典獲得相應(yīng)的數(shù)據(jù)量。
2.大表如何分區(qū)
可根據(jù)月份,季度以及年份等進(jìn)行分區(qū);
3.分區(qū)的表空間規(guī)劃
要對(duì)每個(gè)表空間的大小進(jìn)行估計(jì)
二.創(chuàng)建表分區(qū)
a.創(chuàng)建范圍分區(qū)的關(guān)鍵字是'RANGE'
1.范圍分區(qū)
create table ware_retail_part --創(chuàng)建一個(gè)描述商品零售的數(shù)據(jù)表
(
id integer primary key,--銷售編號(hào)
retail_date date,--銷售日期
ware_name varchar2(50)--商品名稱
)
partition by range(retail_date)
(
--2011年第一個(gè)季度為part_01分區(qū)
partition par_01 values less than(to_date('2011-04-01','yyyy-mm-dd')) tablespace TEMP01,
--2011年第二個(gè)季度為part_02分區(qū)
partition par_02 values less than(to_date('2011-07-01','yyyy-mm-dd')) tablespace TEMP01,
--2011年第三個(gè)季度為part_03分區(qū)
partition par_03 values less than(to_date('2011-10-01','yyyy-mm-dd')) tablespace TEMP01,
--2011年第四個(gè)季度為part_04分區(qū)
partition par_04 values less than(to_date('2012-01-01','yyyy-mm-dd')) tablespace TEMP01
);
2.創(chuàng)建散列分區(qū)
3.組合分區(qū):
4.interval 分區(qū)
三.創(chuàng)建索引分區(qū)
索引分區(qū)分為本地索引分區(qū)和全局索引分區(qū),全局索引不反應(yīng)基礎(chǔ)表的結(jié)構(gòu),要分區(qū)只能進(jìn)行范圍分區(qū)。
創(chuàng)建索引分區(qū)要參照表分區(qū)
四.分區(qū)技術(shù)簡(jiǎn)介
優(yōu)點(diǎn):
1.減少維護(hù)工作量
2.增強(qiáng)數(shù)據(jù)的可用性
3.均衡I/O,提升性能
4.提高查詢速度
5.分區(qū)對(duì)用戶保持透明,用戶感覺(jué)不到分區(qū)的存在。
五,管理表分區(qū)
1.添加表分區(qū)
ALTER TABLE...ALTER PARATITION
2.合并表分區(qū)
3.刪除分區(qū)
ALTER TABLE...DROP PARTITION
刪除分區(qū)時(shí),里面的數(shù)據(jù)也會(huì)被刪除。
-創(chuàng)建表和分區(qū)
create table sales--創(chuàng)建一個(gè)銷售記錄表
(
id number primary key,--記錄編號(hào)
goodsname varchar2(10),--商品名
saledate date--銷售日期
)
partition by range(saledate)--按照日期分區(qū)
(
--第一季度數(shù)據(jù)
partition part_sea1 values less than(to_date('2011-04-01','yyyy-mm-dd')) tablespace tbsp_1,
--第二季度數(shù)據(jù)
partition part_sea2 values less than(to_date('2011-07-01','yyyy-mm-dd')) tablespace tbsp_2,
--第三季度數(shù)據(jù)
partition part_sea3 values less than(to_date('2011-10-01','yyyy-mm-dd')) tablespace tbsp_1,
--第四季度數(shù)據(jù)
partition part_sea4 values less than(to_date('2012-01-01','yyyy-mm-dd')) tablespace tbsp_2
);
--創(chuàng)建局部索引
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
);
--并入分區(qū)
alter table sales merge partitions part_sea3,part_sea4 into partition part_sea4;
--重建局部索引
alter table sales modify partition part_sea4 rebuild unusable local indexes;
六.管理索引分區(qū)
刪除索引:DROP PARTITION
重建分區(qū):REBUILT PARTITION
更名索引分區(qū):RENAME PARTITION
分割索引分區(qū):SPLIT PARTITION