Oracle的分區(qū)可以分為:列表分區(qū)、范圍分區(qū)、散列分區(qū)、復(fù)合分區(qū)。

創(chuàng)新互聯(lián)公司憑借專業(yè)的設(shè)計(jì)團(tuán)隊(duì)扎實(shí)的技術(shù)支持、優(yōu)質(zhì)高效的服務(wù)意識(shí)和豐厚的資源優(yōu)勢(shì),提供專業(yè)的網(wǎng)站策劃、做網(wǎng)站、網(wǎng)站設(shè)計(jì)、網(wǎng)站優(yōu)化、軟件開發(fā)、網(wǎng)站改版等服務(wù),在成都十余年的網(wǎng)站建設(shè)設(shè)計(jì)經(jīng)驗(yàn),為成都數(shù)千家中小型企業(yè)策劃設(shè)計(jì)了網(wǎng)站。
1、增強(qiáng)可用性:如果表的一個(gè)分區(qū)由于系統(tǒng)故障而不能使用,表的其余好的分區(qū)仍可以使用;
2、減少關(guān)閉時(shí)間:如果系統(tǒng)故障只影響表的一部分分區(qū),那么只有這部分分區(qū)需要修復(fù),可能比整個(gè)大表修復(fù)花的時(shí)間更少;
3、維護(hù)輕松:如果需要建表,獨(dú)自管理每個(gè)公區(qū)比管理單個(gè)大表要輕松得多;
4、均衡I/O:可以把表的不同分區(qū)分配到不同的磁盤來(lái)平衡I/O改善性能;
5、改善性能:對(duì)大表的查詢、增加、修改等操作可以分解到表的不同分區(qū)來(lái)并行執(zhí)行,可使運(yùn)行速度更快;
6、分區(qū)對(duì)用戶透明:最終用戶感覺不到分區(qū)的存在。
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ì)用戶保持透明,用戶感覺不到分區(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
一 分區(qū)表技術(shù)概述
二 分區(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ǔ)這兩條記錄
范圍(range)分區(qū):
一::對(duì)于分區(qū)表,如果where條件種沒有分區(qū)列,那么oracle會(huì)掃描所有的分區(qū),然后做PARTITION RANGE
ALL 操作,這樣成本將比未分區(qū)的全表掃描稍微高點(diǎn),因?yàn)樾枰喜⒏鱾€(gè)分區(qū).
二:范圍分區(qū)可以用values less than (maxvalue)增加一個(gè)默認(rèn)分區(qū),maxvalue 常量表示該分區(qū)用來(lái)存放所有其
他分區(qū)無(wú)法存放的記錄,
三:范圍分區(qū)可以對(duì)各種謂詞做分區(qū)消除,包括=,,,等比hash,和list分區(qū)要靈活
oracle分區(qū)表的分區(qū)有四種類型:范圍分區(qū)、散列分區(qū)、列表分區(qū)和復(fù)合分區(qū)。
特點(diǎn)如下:
1、范圍分區(qū)
就是根據(jù)數(shù)據(jù)庫(kù)表中某一字段的值的范圍來(lái)劃分分區(qū)。
數(shù)據(jù)中有空值,Oracle機(jī)制會(huì)自動(dòng)將其規(guī)劃到maxvalue的分區(qū)中。
2、散列分區(qū)
根據(jù)字段的hash值進(jìn)行均勻分布,盡可能地實(shí)現(xiàn)各分區(qū)所散列的數(shù)據(jù)相等。
散列分區(qū)即為哈希分區(qū),Oracle采用哈希碼技術(shù)分區(qū),具體分區(qū)如何由Oracle說(shuō)的算,也可能我下一次搜索就不是這個(gè)數(shù)據(jù)了。
3、列表分區(qū)
列表分區(qū)明確指定了根據(jù)某字段的某個(gè)具體值進(jìn)行分區(qū),而不是像范圍分區(qū)那樣根據(jù)字段的值范圍來(lái)劃分的。
4、復(fù)合分區(qū)
根據(jù)范圍分區(qū)后,每個(gè)分區(qū)內(nèi)的數(shù)據(jù)再散列地分布在幾個(gè)表空間中,這樣我們就要使用復(fù)合分區(qū)。復(fù)合分區(qū)是先使用范圍分區(qū),然后在每個(gè)分區(qū)同再使用散列分區(qū)的一種分區(qū)方法。
比如將part_date的記錄按時(shí)間分區(qū),然后每個(gè)分區(qū)中的數(shù)據(jù)分三個(gè)子分區(qū),將數(shù)據(jù)散列地存儲(chǔ)在三個(gè)指定的表空間中。
擴(kuò)展資料:
分區(qū)的恢復(fù)方法:
如果數(shù)據(jù)庫(kù)運(yùn)行在archive 模式下,那么一旦數(shù)據(jù)庫(kù)損壞則可以通過(guò)冷備份(熱備份)和歸檔備份將數(shù)據(jù)庫(kù)恢復(fù)到斷點(diǎn)狀態(tài)。
數(shù)據(jù)庫(kù)控制文件恢復(fù)(假設(shè)所有控制文件均被破壞):
數(shù)據(jù)庫(kù)基于文件系統(tǒng): 利用操作系統(tǒng)的tar、cp等命令即可。
數(shù)據(jù)庫(kù)基于裸設(shè)備:dd if=$ORACLE_BASE/con.bak of=/dev/rdrd/drd1 seek=12
參考資料來(lái)源:百度百科-oracle數(shù)據(jù)庫(kù)
本文標(biāo)題:oracle表分區(qū)怎么用,oracle分區(qū)表添加分區(qū)
本文網(wǎng)址:http://chinadenli.net/article10/hedogo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、網(wǎng)站改版、品牌網(wǎng)站設(shè)計(jì)、微信公眾號(hào)、外貿(mào)建站、云服務(wù)器
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)