簇和簇表+簇+簇表+创建簇+创建簇表

簇和簇表

1簇是由一组共享相同数据块的多个表组成,它将这些表的相关行一起存储在相同数据块中,这样可以减少查询数据所需的磁盘读取量。
2对于单独使用的表也不应该使用簇。
3简单来说就是2个表中,因为有相同的列,所以将2个表中列值相同的行存储到一个数据块中。
簇表
创建簇后,用户可以在簇中创建创建表,这些表就是簇表。

举例:
有个员工信息表emp,部门信息表dept,这2个表共享部门编号deptno列。如果将emp和dept表组成簇后,在物理上oracle将emp和dept表中有关的每个部门的所有员工信息和部门信息行存储到相同的数据块中,因为簇将不同的表的相关行一起存储到相同的数据中,所以合理使用簇可以减少查询数据多需要的磁盘读取量。而对于单独使用的表也不应该使用簇。

创建簇
create cluster cluster_name(column data_type【,….】)
【pctused 40 |integer】
【pctfree 10 |integer】
【size integer】
【initrans 1 |integer】
【maxtrans 255|integer】
【tablespace tablespace_name】
【storage storage】
cluster_name:簇名称
40 :百分比
pctused 40:在一个数据块中,已经使用的空间,如果降低到百分40,这个数据块才能被使用。
pctfree 10:在一个数据块中,对应保留空间的最小比例为百分10
size :这个簇相关数据行所需的字节数
initrans :在事务处理与分布中,指定在数据块头部的空间大小
maxtrans :并行处理的事务最大数
storage :为表空间的参数进行设置

举例

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

这里写图片描述
创建簇表
在创建一般表的后面使用cluster +簇名(簇字段)

    create table dept_clu(  
    deptno number ,  
    dname varchar2 ( 20 )  
    )  
    cluster my_clu(deptno);  

    create table emp_clu(  
    empno number ,  
    ename varchar2 ( 20 ),  
    deptno number  
    )  
    cluster my_clu(deptno);  

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值