佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Oracle 簇的使用詳解

Oracle 簇的使用詳解

熱門標(biāo)簽:服務(wù)外包 地方門戶網(wǎng)站 網(wǎng)站排名優(yōu)化 Linux服務(wù)器 AI電銷 百度競價排名 呼叫中心市場需求 鐵路電話系統(tǒng)
簇其實就是一組表,由一組共享相同數(shù)據(jù)塊的多個表組成,將經(jīng)常一起使用的表組合在一起成簇可以提高處理效率;在一個簇中的表就叫做簇表。
建立順序是:簇→簇表→簇索引→數(shù)據(jù)
創(chuàng)建簇的格式
CREATE CLUSTER cluster_name
(column date_type [,column datatype]...)
[PCTUSED 40 | integer] [PCTFREE 10 | integer]
[SIZE integer]
[INITRANS 1 | integer] [MAXTRANS 255 | integer]
[TABLESPACE tablespace]
[STORAGE storage]
SIZE:指定估計平均簇鍵,以及與其相關(guān)的行所需的字節(jié)數(shù)。
1、創(chuàng)建簇
復(fù)制代碼 代碼如下:

    create cluster my_clu (deptno number ) 
    pctused 60 
    pctfree 10 
    size 1024 
    tablespace users 
    storage ( 
    initial 128 k 
    next 128 k 
    minextents 2 
    maxextents 20 
    ); 

2、創(chuàng)建簇表
復(fù)制代碼 代碼如下:

    create table t1_dept( 
    deptno number , 
    dname varchar2 ( 20 ) 
    ) 
    cluster my_clu(deptno); 
    create table t1_emp( 
    empno number , 
    ename varchar2 ( 20 ), 
    birth_date date , 
    deptno number 
    ) 
    cluster my_clu(deptno); 

3、為簇創(chuàng)建索引
復(fù)制代碼 代碼如下:

create index clu_index on cluster my_clu;

注:若不創(chuàng)建簇索引,則在插入數(shù)據(jù)時報錯:ORA-02032: clustered tables cannot be used before the cluster index is built
管理簇
使用ALTER修改簇屬性(必須擁有ALTER ANY CLUSTER的權(quán)限)
1、修改簇屬性
可以修改的簇屬性包括:
* PCTFREE、PCTUSED、INITRANS、MAXTRANS、STORAGE
* 為了存儲簇鍵值所有行所需空間的平均值SIZE
* 默認(rèn)并行度
注:
* 不能修改INITIAL和MINEXTENTS的值
* PCTFREE、PCTUSED、SIZE參數(shù)修改后適用于所有數(shù)據(jù)塊
* INITRANS、MAXTRANS僅適用于以后分配的數(shù)據(jù)塊
* STORAGE參數(shù)修改后僅影響以后分配給簇的盤區(qū)
例:
復(fù)制代碼 代碼如下:

    alter cluster my_clu 
    pctused 40 

2、刪除簇
復(fù)制代碼 代碼如下:

    drop cluster my_clu; -- 僅適用于刪除空簇 
    drop cluster my_clu including tables ; -- 刪除簇和簇表 
    drop cluster my_clu including tables cascade constraints ;--同時刪除外鍵約束 

注:簇表可以像普通表一樣刪除。
3、清空簇
復(fù)制代碼 代碼如下:

truncate cluster my_clu;

注:所有在此簇上的表的數(shù)據(jù)全部被清空
散列聚簇表
在簇表中,Oracle使用存儲在索引中的鍵值來定位表中的行,而在散列聚簇表中,使用了散列函數(shù)代替了簇索引,先通過內(nèi)部函數(shù)或者自定義的函數(shù)進(jìn)行散列計算,然后再將計算得到的碼值用于定位表中的行。創(chuàng)建散列簇需要用到HASHKEYS子句。
1、創(chuàng)建散列簇
復(fù)制代碼 代碼如下:

    create cluster my_clu_two(empno number(10) ) 
    pctused 70 
    pctfree 10 
    tablespace users 
    hash is empno 
    hashkeys 150 ; 

說明:
* hash is 子句指明了進(jìn)行散列的列,如果列是唯一的標(biāo)示行,就可以將列指定為散列值
* hashkeys 指定和限制散列函數(shù)可以產(chǎn)生的唯一的散列值的數(shù)量
2、創(chuàng)建散列表
復(fù)制代碼 代碼如下:

    create table t2_emp ( 
    empno number ( 10 ), 
    ename varchar2 ( 20 ), 
    birth_date date , 
    deptno number ) 
    cluster my_clu_two(empno); 

注意:
* 必須設(shè)置數(shù)值的精度
* 散列簇不能也不用創(chuàng)建索引
* 散列簇不能ALTER:size、hashkeys、hash is參數(shù)
不宜用聚簇表的情況
1)如果預(yù)料到聚簇中的表會大量修改,聚簇表會對DML的性能產(chǎn)生負(fù)面影響
2)非常不適合對單表的全表掃描,因為只能引起對其它表的全表掃描
3)頻繁對表進(jìn)行TRUNCATE和加載,因為聚簇中的表是不能TRUNCATE的,只能TRUNCATE簇
4)如果表只是偶爾被連接或者它們的公共列經(jīng)常被修改,則不要聚簇表
5)如果經(jīng)常從所有有相同聚簇鍵值的表查詢出的結(jié)果數(shù)據(jù)超過一個或兩個Oracle塊,則不要聚簇表
6)如果空間不夠,并且不能為將要插入的新記錄分配額外的空間,那么不要使用聚簇

標(biāo)簽:湖南 崇左 蘭州 衡水 仙桃 銅川 湘潭 黃山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Oracle 簇的使用詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    乌兰浩特市| 绥宁县| 安义县| 龙里县| 长丰县| 安徽省| 卢湾区| 长泰县| 额尔古纳市| 门头沟区| 聂拉木县| 上思县| 绥化市| 大理市| 石棉县| 和林格尔县| 卓尼县| 镇平县| 高清| 江油市| 渝中区| 酉阳| 衢州市| 资兴市| 山丹县| 华宁县| 泾川县| 安龙县| 礼泉县| 武山县| 离岛区| 琼结县| 水城县| 清新县| 福建省| 棋牌| 祁阳县| 石家庄市| 新兴县| 苗栗县| 海原县|