欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle 簇的使用詳解

 更新時(shí)間:2013年05月31日 09:54:02   作者:  
本篇文章是對Oracle中簇的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
簇其實(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)錯: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 ;--同時(shí)刪除外鍵約束 

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

truncate cluster my_clu;

注:所有在此簇上的表的數(shù)據(jù)全部被清空
散列聚簇表
在簇表中,Oracle使用存儲在索引中的鍵值來定位表中的行,而在散列聚簇表中,使用了散列函數(shù)代替了簇索引,先通過內(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 ; 

說明:
* 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)非常不適合對單表的全表掃描,因?yàn)橹荒芤饘ζ渌淼娜頀呙?BR>3)頻繁對表進(jìn)行TRUNCATE和加載,因?yàn)榫鄞刂械谋硎遣荒躎RUNCATE的,只能TRUNCATE簇
4)如果表只是偶爾被連接或者它們的公共列經(jīng)常被修改,則不要聚簇表
5)如果經(jīng)常從所有有相同聚簇鍵值的表查詢出的結(jié)果數(shù)據(jù)超過一個(gè)或兩個(gè)Oracle塊,則不要聚簇表
6)如果空間不夠,并且不能為將要插入的新記錄分配額外的空間,那么不要使用聚簇

相關(guān)文章

  • Oracle11g簡單安裝和使用教程

    Oracle11g簡單安裝和使用教程

    這篇文章主要為大家詳細(xì)介紹了Oracle11g簡單安裝和使用教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • CenterOs7 安裝oracle19c的方法詳解

    CenterOs7 安裝oracle19c的方法詳解

    這篇文章主要介紹了CenterOs7 安裝oracle19c的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • Oracle 創(chuàng)建主鍵自增表示例代碼

    Oracle 創(chuàng)建主鍵自增表示例代碼

    我們經(jīng)常在設(shè)計(jì)數(shù)據(jù)庫的時(shí)候用一個(gè)系統(tǒng)自動分配的ID來作為我們的主鍵,但是在Oracle沒有自增主鍵的設(shè)置,我們可以通過這篇文章介紹的方法實(shí)現(xiàn),有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-10-10
  • Oracle切換為歸檔模式的步驟及問題解決

    Oracle切換為歸檔模式的步驟及問題解決

    這篇文章主要介紹了Oracle切換為歸檔模式的步驟,還有遇到的問題解決方法,大家參考使用吧
    2013-11-11
  • Oracle如何通過執(zhí)行計(jì)劃查看查詢語句是否使用索引

    Oracle如何通過執(zhí)行計(jì)劃查看查詢語句是否使用索引

    這篇文章主要介紹了Oracle如何通過執(zhí)行計(jì)劃查看查詢語句是否使用索引問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Oracle同步數(shù)據(jù)到kafka的方法

    Oracle同步數(shù)據(jù)到kafka的方法

    本文主要介紹如何使用kafka-connect-oracle開源工具,將Oracle?dml產(chǎn)生的數(shù)據(jù)實(shí)時(shí)同步至kafka,供kafka消費(fèi),對Oracle同步數(shù)據(jù)到kafka的方法感興趣的朋友一起看看吧
    2022-02-02
  • 教你如何靜默安裝ORACLE

    教你如何靜默安裝ORACLE

    這篇文章主要介紹了教你如何靜默安裝ORACLE,需要的朋友可以參考下
    2014-08-08
  • Oracle DATABASE LINK(DBLINK)創(chuàng)建與刪除方法

    Oracle DATABASE LINK(DBLINK)創(chuàng)建與刪除方法

    這篇文章主要介紹了Oracle DATABASE LINK(DBLINK)創(chuàng)建與刪除方法,需要的朋友可以參考下
    2016-02-02
  • Oracle中如何把表和索引放在不同的表空間里

    Oracle中如何把表和索引放在不同的表空間里

    Oracle中并沒有區(qū)分表空間里放的是表還是索引,所有當(dāng)數(shù)據(jù)量比較小時(shí),完全可以把表和索引放在同一個(gè)表空間里,但隨著數(shù)據(jù)量的增大,最好還是把表和索引分開存儲在不同的表空間里
    2013-07-07
  • Oracle修改表空間大小的方法

    Oracle修改表空間大小的方法

    這篇文章主要介紹了Oracle修改表空間大小的方法,實(shí)例講述了Oracle通過命令行實(shí)現(xiàn)修改Oracle表空間大小的方法,非常簡單實(shí)用,需要的朋友可以參考下
    2015-12-12

最新評論