关闭

匹配表类型与业务需求

标签: oracle
103人阅读 评论(0) 收藏 举报
分类:

问题描述:oracle提供了非常多的表类型供选择,根据特定的业务需求选择合适类型的表对于性能有很大的影响


解决方案:

oracle创建的表默认是堆组织表,大多数情况,堆组织表可以提供高效的数据存取,下面有其他一些表类型:

堆组织表:默认的表类型,除非有特殊原因,否则就是用这种表

索引组织表:数据存放在一个按照主键排序的索引结构中,通常用于按照主键查找

临时表:用于在事物或者会话期间保存临时数据,所用空间在临时段中分配,当需要一个临时结构存放数据时可使                  用,数据在事物结束或会话断开时自动清楚

分区表:将多个物理分割的段逻辑组织在一起,通常数据量大

物化视图:保存某条sql执行结果的表,按照需要,可定时刷新,在报表系统或数据复制方面很高效

聚簇:共享相同存储块的一组表,用于经常要对相同列连接的表,以减少表的io

外部表:用于在操作系统和数据库之间做数据读取,利用这种表可以快速以表的形式的读取操作系统的文件,例如                  csv或者文本文件

嵌套表:一个表的某个列的类型是另一张表

对象:一个表的某个列的类型是一个对象类型


工作原理:

通常情况下,堆组织表就可以满足需求,除非有特殊的需求。

例如:oracle分区是创建大表和索引的可扩展方法

物化视图对于数据聚集和复制都很高效

当表的大多数列都是主键的一部分,可考虑索引组织表,例如多对多的中间表

使用新特性时应清楚其优劣,不能听起来感觉酷,就用

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:5494次
    • 积分:241
    • 等级:
    • 排名:千里之外
    • 原创:19篇
    • 转载:1篇
    • 译文:0篇
    • 评论:0条
    文章存档