`
fudehai001
  • 浏览: 500296 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

ORACLE 簇的详细介绍

阅读更多
1. 什么是聚簇
    聚簇是根据码值找到数据的物理存储位置,从而达到快速检索数据的目的。聚簇索引的顺序就是数据的物理存储顺序,叶节点就是数据节点。非聚簇索引的顺序与数据物理排列顺序无关,叶节点仍然是索引节点,只不过有一个指针指向对应的数据块。一个表最多只能有一个聚簇索引。
    2. 使用 Oracle 聚簇索引
    聚簇是一种存储表的方法,这些表密切相关并经常一起连接进磁盘的同一区域。例如,表 BOOKSHELF 和BOOKSHELF_AUTHOR 数据行可以一起插入到称为簇(Cluster)的单个区域中,而不是将两个表放在磁盘上的不同扇区上。簇键(Cluster Key)可以是一列或多列,通过这些列可以将这些表在查询中连接起来(例如,BOOKSHELF表和BOOKSHELF_AUTHOR表中的 Title列)。为了将表聚集在一起,必须拥有这些将要聚集在一起的表。
    下面是create cluster命令的基本格式:
create cluster (column datatype [, column datatype]...) [other options];
    cluster的名字遵循表命名约定,column datatype是将作为簇键使用的名字和数据类型。column的名字可以与将要放进该簇中的表的一个列名相同,或者为其他有效名字。下面是一个例子:
create cluster BOOKandAUTHOR (Col1 VARCHAR2(100));
    这样就建立了一个没有任何内容的簇(象给表分配了一块空间一样)。COL1的使用对于簇键是不相干的,不会再使用它。但是,它的定义应该与要增加的表的主键相符。接下来,建立包含在该簇中的表:
create table BOOKSHELF
    (Title VARCHAR2(100) primary key,
    Publisher VARCHAR2(20),
    CategoryName VARCHAR2(20),
    Rating VARCHAR2(2),
    constraint CATFK foreign key (CategoryName) references CATEGORY(CategoryName)
    )
    cluster BOOKandAUTHOR(Title);
    在向BOOKSHELF表中插入数据行之前,必须建立一个聚簇索引:
create index BOOKandAUTHORndx on cluster BOOKandAUTHOR;
    在上面的create table语句中,簇BOOKandAUTHOR(Title)子句放在表的列清单的闭括号的后面。BOOKandAUTHOR是前面建立的聚簇的名字。Title是将存储到聚簇Col1中的该表的列。create cluster语句中可能会有多个簇键,并且在created table语句中可能有多个列存储在这些键中。请注意,没有任何语句明确说明Title列进入到Col1中。这种匹配仅仅是通过位置做到的,即Col1和Title都是在它们各自的簇语句中提到的第一个对象。多个列和簇键是第一个与第一个匹配,第二个与第二个匹配,第三个与第三个匹配,等等。现在,添加第二个表到聚簇中:
create table BOOKSHELF_AUTHOR
    (Title VARCHAR2(100),
    AuthorName VARCHAR2(50),
    constraint TitleFK Foreign key (Title) references BOOKSHELF(Title),
    constraint AuthorNameFK Foreign key (AuthorName) references AUTHOR(AuthorName)
    )
    cluster BOOKandAUTHOR (Title);
    当这两个表被聚在一起时,每个唯一的Title在簇中实际只存储一次。对于每个Title,都从这两个表中附加列。
    来自这两个表的数据实际上存放在一个位置上,就好像簇是一个包含两个表中的所有数据的大表一样。
    3. 散列聚簇
    对于散列聚簇,它只有一个表。它通过散列算法求出存储行的物理存储位置,从而快速检索数据。创建散列聚簇时要指定码列的数据类型,数据行的大小及不同码值的个数。如果码值不是平均分布的,就可能有许多行存储到溢出块上,从而会降低查询该表的SQL语句的性能。
    散列聚簇被用在总是通过主键查询数据的情况,例如要从表 T 查询数据并且查询语句总是是这样:
select * from T where id =;
    这时散列聚簇是一个好的选择,因为不需要索引。Oracle 将通过散列算法得到值 所对应的物理地址,从而直接取到数据。不用进行索引扫描,只通过散列值进行一次表访问。
    散列聚簇语法示例:
CREATE CLUSTER personnel
    ( department_number NUMBER )
    SIZE 512 HASHKEYS 500
    STORAGE (INITIAL 100K NEXT 50K);

    CREATE CLUSTER personnel
    ( home_area_code NUMBER,
    home_prefix NUMBER )
    HASHKEYS 20
    HASH IS MOD(home_area_code + home_prefix, 101);
    CREATE CLUSTER personnel
    (deptno NUMBER)
    SIZE 512 SINGLE TABLE HASHKEYS 500;
分享到:
评论

相关推荐

    Oracle中聚簇表的使用

    ### Oracle中聚簇表的使用 #### 聚簇表的概念 在Oracle数据库中,聚簇表(Cluster Table)是一种特殊的数据存储结构,它允许多个表通过共享某些相同的列值来存储在同一个数据块内。这种特性使得相关联的数据能够在...

    Oracle中聚簇表Cluster Table使用图文详解

    大家通常oracle中的cluster的理解是不准确的,经常和sql server中的cluster index混淆。Cluster是存储一组table的一种方法,这些table共享同一数据块中的某些相同column,并把不同table在这一共享column上值相同的...

    Oracle 簇的使用详解

    Oracle 簇是一种数据库优化技术,它允许将一组相关联的表存储在同一组数据块中,从而提高了查询性能,特别是当这些表经常一起被访问时。簇中的表称为簇表,它们共享相同的物理存储,减少了磁盘I/O,提升了数据访问...

    Oracle 11g Concepts中英文对照.pdf

    为帮助用户更好地理解和使用 Oracle 11g,我们将从以下几个方面对 Oracle 11g 的概念进行详细介绍。 数据库管理系统(DBMS) 数据库管理系统(DBMS)是指管理和存储数据的软件系统。DBMS 提供了一个强大的平台,...

    Oracle Index 索引介绍

    **Oracle索引详解** Oracle索引是数据库管理系统中用于提高查询效率的重要数据结构。它的工作原理类似于书籍的目录,允许数据库系统快速定位到所需的数据行,而无需扫描整个表。索引的存在使得对大量数据的查找、...

    Oracle 9i10g 数据库管理详细

    ### Oracle 9i/10g 数据库管理详细知识点 #### 一、Oracle 9i/10g 概述 - **Oracle 9i** 和 **Oracle 10g** 是Oracle公司推出的两个重要的数据库管理系统版本。这些版本在企业级数据库管理领域具有重要意义。 - *...

    Oracle数据库体系结构( 中文详细版)

    本文将详细解析Oracle数据库的体系结构,帮助读者深入理解其内部工作原理。 Oracle数据库的核心架构可以分为以下几个主要部分: 1. **数据文件**(Data Files):数据文件是Oracle数据库存储实际数据的地方,包含...

    高性能动态SQL Oracle数据安全 Oracle 数据库的聚簇技术 等等

    Oracle数据库是世界上最广泛使用的数据库管理系统之一,以其高效、稳定和强大的功能著称。本文将深入探讨Oracle的一些核心知识点,包括数据导入导出、系统性能优化、动态SQL、数据安全以及数据库的架构和管理。 1. ...

    oracle 11g concepts

    本压缩包包含的官方文档详细阐述了Oracle 11g的核心概念,对于想要深入学习Oracle数据库的人来说是不可或缺的资源。 首先,从“Oracle_11gR2_概念_第1章_Oracle_数据库简介.pdf”中,我们可以了解到Oracle数据库的...

    Oracle_11gR2_概念 oracle白皮书 concept

    紧接着,对表的基本概念、表簇(包括索引化表簇和哈希簇)进行了详细介绍,还包括表的示例创建与修改语句、Oracle数据类型、完整性约束、对象表、临时表、外部表和表存储等内容。 第3章索引和索引组织表,主要介绍...

    oracle官网参考资料-最新最完整

    这份“oracle官网参考资料-最新最完整”压缩包包含了最新的Oracle官方文档,这些文档详细且全面地介绍了Oracle数据库的各种特性和使用方法,对于学习、研究或在工作中使用Oracle数据库的人来说是一份极其宝贵的资源...

    ORACLE 19C SQL调优指南 中文版 Oracle DBA

    12. **数据库架构调整**:包括表空间管理、数据分布策略(如表分区、簇、位图索引等)、以及数据库块大小的选择,都会影响性能。 13. **SQL优化工具**:Oracle提供了一些内置工具,如SQL Tuning Advisor和Automatic...

    Oracle\Oracle DBA课程安排.doc

    以下是对这些核心内容的详细解释: 1. **Oracle DBA职责与任务**:DBA负责监控、维护、优化数据库性能,确保数据的安全性和完整性,执行备份与恢复操作,并处理数据库的故障。 2. **Oracle服务器安装**:包括...

    Oracle数据库技术大全

    第12章 数据库的恢复详细介绍了Oracle的恢复机制,包括RMAN(恢复管理器)的使用、归档日志和闪回技术。理解这些恢复方法对于保障数据库的高可用性极其关键。 第14章 数据库资源管理器则讨论了如何利用Oracle的资源...

    杭州电子科技大学oracle课堂ppt

    首先,"第一讲 Oracle数据库概述"介绍了Oracle数据库的基本概念,包括数据库的定义、Oracle的历史以及它在业界的地位。这部分内容可能会涵盖Oracle的特点,如分布式数据库、高可用性解决方案以及强大的数据管理能力...

    Oracle 9i BDA.pdf

    - **启动和关闭数据库**:详细讲解如何启动、关闭数据库,并介绍在不同情况下的特殊操作,如禁止操作数据库、暂停和继续数据库等。 #### 2. 服务器进程与存储结构 - **Oracle进程管理**:包括服务器进程、后台进程...

    Oracle体系结构简介

    以下是对Oracle体系结构主要组成部分的详细说明: 1. **数据库**:数据库是Oracle的核心,它是一个逻辑数据集合,包含了物理存储的数据以及元数据。Oracle是关系型数据库管理系统(RDBMS),意味着它以表格形式组织...

    oracle10g文档.pdf

    - **Oracle数据字典纵览**:Oracle 10g 使用数据字典来存储有关数据库的所有元数据信息,这部分内容会详细介绍数据字典的重要性及如何使用。 - **Oracle实例纵览**:一个Oracle实例由后台进程和内存结构组成,这...

Global site tag (gtag.js) - Google Analytics