微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Oracle三种table: 堆表Heap Table、索引组织表IOT和聚簇表Cluster

常用数据库支持情况:
Oracle支持堆表,索引组织表,聚簇表Cluster;
Postgresql支持堆表,不支持索引组织表;
Innodb只支持索引组织表;
MyISAM只支持堆表。

Oracle使用rowid数据类型存储行地址,rowid可以分成两种,分别适于不同的对象,
Physical rowids:存储ordinary table,clustered table,table partition and subpartition,indexe,index partition and subpartition;
Logical rowids :存储IOT的行地址


Heap table:无序的集合存储。表和主键索引分成两个segment。创建的主键索引叶结点存储ROWID。

插入和更新快,结果无序。

从成本上计算,CBO并不是因为回表动作才确定执行计划,而是Clustering Factor的影响。IOT一个突出优势就是直接消灭了Clustering Factor的成本因素。


http://blog.sina.com.cn/s/blog_4b12778b0101cgl9.html
http://blog.sina.com.cn/s/blog_4b12778b0101cglt.html

http://blog.csdn.net/dnnyyq/article/details/5195472
http://www.jb51.cc/article/p-ongulytx-kd.html

IOT: 主键和表合成一个segment。数据是按主键有序的存储在B树索引结构中。叶结点存储了行记录。查询快,不回表,结果有序,插入和更新慢。

createtablet88(

IDvarchar2(10),

NAMEvarchar2(20),128)">constraintpk_idprimarykey(ID)

)

organizationindex

PCTTHRESHOLD20

overflowtablespaceusers

INCLUDINGname;

注意两点:

● 创建IOT时,必须要设定主键,否则报错。

● 索引组织表实际上将所有数据都放入了索引中。


索引组织表的适用情况:适用于信息检索、空间和OLAP程序。
1、 代码查找表。
2、 经常通过主码访问的表。
3、 构建自己的索引结构。
4、 加强数据的共同定位,要数据按特定顺序物理存储。
5、 经常用between…and…对主码或唯一码进行查询。数据物理上分类查询。如一张订单表,按日期装载数据,想查单个客户不同时期的订货和统计情况。

经常更新的表当然不适合IOT。如果不是经常使用主键访问表,就不要使用IOT。


http://m.blog.itpub.net/17203031/viewspace-774405 聊聊Oracle聚簇Cluster

Cluster table:多个表合成一个segment存储,多个数据表按照连接键的顺序保存在一起。经常和另外一个数据表进行连接查询(Join)显示

create cluster emp_dept (deptno number) size 600; create table emp (empno number,empname varchar2(10),deptno number) cluster emp_dept(deptno); create table dept (deptno number primary key,deptname varchar2(10)) cluster emp_dept(deptno); create index idx_emp_dept on cluster emp_dept; insert into dept select deptno,dname from scott.dept; insert into emp select empno,ename,deptno from scott.emp; drop cluster emp_dept including tables;

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Java Oracle 结果集是Java语言中处理数据库查询结果的一种方式。通常情况下,Java程序会通过JDBC连接Oracle数据库并执行一条查询语句,返回一个ResultSet结果集。ResultSet是一个行集,包含了查询语句的返回结果。在
Java AES和Oracle AES是现代加密技术中最常使用的两种AES加密。在计算机通信领域,AES加密算法是一种十分重要的保密技术,被广泛应用于银行、保险、互联网电子支付等重要场合。
Java是一种广泛应用的编程语言,具备可靠性、安全性、跨平台性等优势,被广泛应用于企业级应用开发。而Oracle11g是一个强大的关系型数据库,由于其优秀的可靠性、安全性和扩展性,已经被广泛应用于企业级应用中。Jav
随着移动互联网的发展,抽奖活动成为了营销活动中不可或缺的组成部分。为了满足移动端用户的需求,我们可以使用jQuery开发移动端大转盘抽奖活动。
Java和Oracle都是在计算机领域应用非常广泛的技术,他们经常被用来搭建高效的软件系统。Java是一种面向对象的编程语言,而Oracle是一种关系型数据库管理系统。Java 和Oracle在应用中的联系非常紧密,它们能够通过相互
Java 是一门非常流行的编程语言,它可以运行于各种操作系统上,而 Oracle 是一个广泛使用的数据库软件。在 Java 对 Oracle 进行操作时,需要使用 Oracle 参数来确保程序正确工作。本文将从 Oracle 参数的定义、分类
随着电子竞技的兴起,越来越多的人开始慕名玩起了王者荣耀。而对于Python爱好者来说,这款游戏也有着很大的吸引力。因为Python可以帮助我们获取并处理游戏数据,从而获得更好的游戏体验。
Java与Oracle在数据处理方面都有着非常重要的地位,而在Java和Oracle的结合中,Integer类型则起到了不可替代的作用。Integer类型是Java中一个非常常用的数据类型,它可以表示范围在-2147483648到2147483647之间的整数
如今,JavaScript已经成为了web开发的必备技能之一,而IE浏览器也是众多开发者最常用的浏览器,那么,如何启用IE浏览器的JavaScript呢?
Java与Oracle是当今软件行业中广泛使用的两个技术。而SP(Stored Procedure)是Oracle数据库中存储过程的组件,可以在Java中调用Oracle数据库中的SP。在开发过程中,Java和Oracle的组合可以方便处理大规模的数据和建