国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > Oracle > 正文

Oracle 簇的使用詳解

2020-07-26 14:25:22
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
簇其實(shí)就是一組表,由一組共享相同數(shù)據(jù)塊的多個(gè)表組成,將經(jīng)常一起使用的表組合在一起成簇可以提高處理效率;在一個(gè)簇中的表就叫做簇表。
建立順序是:簇→簇表→簇索引→數(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:指定估計(jì)平均簇鍵,以及與其相關(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ù)時(shí)報(bào)錯(cuò):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
* 為了存儲(chǔ)簇鍵值所有行所需空間的平均值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 ;--同時(shí)刪除外鍵約束 

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

truncate cluster my_clu;

注:所有在此簇上的表的數(shù)據(jù)全部被清空
散列聚簇表
在簇表中,Oracle使用存儲(chǔ)在索引中的鍵值來(lái)定位表中的行,而在散列聚簇表中,使用了散列函數(shù)代替了簇索引,先通過(guò)內(nèi)部函數(shù)或者自定義的函數(shù)進(jìn)行散列計(jì)算,然后再將計(jì)算得到的碼值用于定位表中的行。創(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 ; 

說(shuō)明:
* 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ù)料到聚簇中的表會(huì)大量修改,聚簇表會(huì)對(duì)DML的性能產(chǎn)生負(fù)面影響
2)非常不適合對(duì)單表的全表掃描,因?yàn)橹荒芤饘?duì)其它表的全表掃描
3)頻繁對(duì)表進(jìn)行TRUNCATE和加載,因?yàn)榫鄞刂械谋硎遣荒躎RUNCATE的,只能TRUNCATE簇
4)如果表只是偶爾被連接或者它們的公共列經(jīng)常被修改,則不要聚簇表
5)如果經(jīng)常從所有有相同聚簇鍵值的表查詢出的結(jié)果數(shù)據(jù)超過(guò)一個(gè)或兩個(gè)Oracle塊,則不要聚簇表
6)如果空間不夠,并且不能為將要插入的新記錄分配額外的空間,那么不要使用聚簇
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 巨鹿县| 象州县| 新绛县| 中西区| 阿拉善左旗| 乐都县| 惠安县| 竹溪县| 明溪县| 信丰县| 麻栗坡县| 柯坪县| 仙居县| 绥滨县| 汕头市| 昭通市| 江津市| 夏河县| 新邵县| 西丰县| 清苑县| 安乡县| 甘南县| 都江堰市| 平度市| 内丘县| 玉田县| 绥芬河市| 招远市| 商丘市| 历史| 阿尔山市| 瑞昌市| 分宜县| 奎屯市| 南阳市| 察哈| 南靖县| 南丰县| 岳西县| 遂平县|