Oracle 支持两种类型的聚簇:索引聚簇和哈希聚簇
使用索引聚簇指南
l 考虑对经常在连接语句中访问的表建立聚簇。
l 如果表只是偶尔被连接或者它们的公共列经常被修改,则不要聚簇表。(修改记录的聚簇键值比在非聚簇的表中修改此值要花费更多的时间,因为 Oracle 必须将修改的记录移植到其他的块中以维护聚簇)。
l 如果经常需要在一个表上进行完全搜索,则不要聚簇这个表(对一个聚簇表进行完全搜索比在非聚簇表上进行完全搜索的时间长, Oracle 可能要读更多的块,因为表是被一起存储的。)
l 如果经常从一个父表和相应的子表中查询记录,则考虑给 1 对多( 1:* )关系创建聚簇表。(子表记录存储在与父表记录相同的数据块中,因此当检索它们时可以同时在内存中,因此需要 Oracle 完成较少的 I/O )。
l 如果经常查询同一个父表中的多个子记录,则考虑单独将子表聚簇。(这样提高了从相同的父表查询子表记录的性能,而且也没有降低对父表进行完全搜索的性能)。
l 如果从所有有相同聚簇键值的表查询的数据超过一个或两个 Oracle 块,则不要聚簇表。(要访问在一个聚簇表中的记录, Oracle 读取所有包含那个记录值的全部数据块,如果记录占据了多个数据块,则访问一个记录需要读的次数比一个非聚簇的表中访问相同的记录读的次数要多)。
使用哈希聚簇指南
l 当经常使用有相同列的包含相等条件的查询子句访问表时,考虑使用哈希聚簇来存储表。使用这些列作为聚簇键。
l 如果可以确定存放具有给定聚簇键值的所有记录所需的空间(包括现在的和将来的),则将此表以哈希聚簇存储。
l 如果空间不够,并且不能为将要插入的新记录分配额外的空间,那么不要使用哈希聚簇。
l 如果偶尔创建一个新的、很大的哈希聚簇来保存这样的表是不切实际的,那么不要用哈希聚簇存储经常增长的表。
l 如果经常需要进行全表搜索,并且必须要为表的预期增长中的哈希聚簇分配足够的空间,则不要将此表以哈希聚簇存储。(这样的完全检索必须要读分配给哈希聚簇的全部块,即使有些块可能只包含很少的记录。单独地存储表将减少由完全的表检索读取的块的数量。)
l 如果你的应用程序经常修改聚簇键的值,则不要将表以哈希聚簇方式存储。
l 不管这个表是否经常与其他表连接,只要进行哈希对于基于以前的指南的表是合适的,那么在哈希聚簇中存储一个表可能是有用的。
分享到:
相关推荐
- 使用聚簇可以有效减少查询时的数据扫描范围,特别是在多表关联查询中能显著提升效率。 3. **利用RAID技术:** - 利用RAID 5或RAID 6等技术可以进一步提高I/O性能,并提供数据冗余保障。 4. **监控I/O负载:** ...
- **示例**:物理数据模型可能包括索引(Index)、聚簇(Clustering)等优化数据访问的技术。 **4. 数据模型的三要素** - **数据结构**:描述数据的组织方式,如记录、字段等。 - **数据操作**:定义可以在数据上执行...
3.1 表/索引/聚簇分析:通过ANALYZE命令收集统计信息,优化查询性能。 3.2 检查表空间碎片:碎片整理可以提高空间利用率和查询效率。 3.3 寻找性能调整机会:通过性能监控找到瓶颈,进行针对性优化。 3.4 数据库性能...
《数据库实用编程手册》是一本综合性的数据库编程指南,涵盖了Oracle、MySQL和SQL Server这三大主流关系型数据库系统的使用方法和常见问题解决策略。对于数据库开发者,无论是新手还是经验丰富的专家,都是一份...
此外,索引是提高查询性能的关键,非聚簇索引和聚簇索引是两种主要类型,分别根据键值的顺序和数据行的位置来组织。 在安全性方面,SQL Server提供了用户权限管理,允许管理员控制不同用户对数据库的访问级别。角色...
非聚簇索引和聚簇索引是两种主要类型的索引,它们对数据存储方式有不同的影响。 数据库的事务处理和并发控制也是重点。事务是一系列操作的逻辑单元,具有原子性、一致性、隔离性和持久性的ACID特性。并发控制确保多...
1. 索引类型:介绍B树索引、聚簇索引、非聚簇索引等,以及如何选择合适的索引类型。 2. 查询优化:讨论查询优化器的工作原理,如何编写高效的SQL语句,以及使用EXPLAIN计划来分析查询性能。 七、复制技术 1. 数据...