
表 1:SQL Server 2005 分区表与分区视图
功能 分区表 分区视图
表的维护
表作为单个实体来管理。
每个参与的表各自都是一个实体,必须对其进行元数据更改。
每个分区必须具有相同的索引。
每个表可以具有各自的索引策略。
实现
两者在实现的复杂程度方面大致相同。发生问题时,分区表会更明确地引发错误。
可能会存在隐蔽的问题使分区视图无法按预期进行 *** 作。一个常见问题是创建检查约束而没有检查当前值。分区视图能够成功实现,但由于不明原因而不能正确进行优化。
编译时间
由于所有分区的索引方式都一样,因此优化器可以对每个分区使用相同的执行计划,从而使编译时间大大缩短。
由于分区可以具有不同的索引,因此优化器必须针对每个表(分区)来估计最佳执行计划。当分区视图中存在很多表时,编译时间将会很长。
加载
可以从外部加载分区,从而将对表当前用户的影响降至最低。
可以从外部加载表,从而将对视图当前用户的影响降至最低。
切换入新数据
是一种快捷的元数据 *** 作,将自然进行排队。
是一种元数据 *** 作,但是 ALTER VIEW 语句会无限期地等待 SCHEMA 锁。
可更新性
除了创建分区表所需的规则以外,不必遵守其他特殊规则来使该表可更新。分区表可以具有标识列,不需要主键等。
存在一些使得分区视图难以具备可更新性的限制,例如参与的表没有标识列并且存在主键。这通常意味着必须直接更新基础表,这样就使得 INSERT 和 UPDATE 的编码复杂化。
备份/还原
可以单独或一起备份/还原表的分区,具体取决于文件组的实现方案。
注: 除非文件组被标记为只读,否则还原文件组需要从备份点开始重新应用事务日志。
可以单独或一起备份/还原构成分区视图的各个表,具体取决于文件组的实现方案。
分区视图表还可以驻留在单独的数据库中,这样就可以对单独的分区进行单独的数据库备份。
注:除非文件组被标记为只读,否则还原文件组需要从备份点开始重新应用事务日志。
数据库内容
一个分区表中的所有分区必须驻留在同一个数据库中。
参与分区视图的各个表可以驻留在不同的数据库中。这就使得对历史记录段的备份和还原 *** 作非常容易实现。
查询并行处理
在并行查询计划中,各个分区是并行处理的单元。如果查询仅涉及单个分区,将不通过并行处理访问该表。
将单独考察分区视图中的每个表,以确定是否进行并行查询访问。如果查询仅涉及单个表,则可以通过并行处理访问该表。
批量加载
分区表可以直接作为批量插入/备份 *** 作的目标。
分区视图不能作为批量插入/备份 *** 作的目标 – 目标必须是视图中的各个表。
Oracle 分区功能可以提高许多应用程序的可管理性 性能与可用性 通过分区功能 可以将表 索引和索引组织表进一步细分为段 从而能够更精确地管理和访问这些数据库对象 Oracle 提供了种类繁多的分区方案以满足每种业务要求 而且 因为在 SQL 语句中分区是完全透明的 所以该功能几乎可应用于任何应用程序
分区功能的优势
分区功能通过改善可管理性 性能和可用性 从而为各式应用程序带来了极大的好处 通常 分区可以使某些查询以及维护 *** 作的性能大大提高 此外 分区还可以极大简化常见的管理任务 通过分区 数据库设计人员和管理员能够解决前沿应用程序带来的一些难题 分区是构建千兆字节数据系统或超高可用性系统的关键工具
分区功能的基本知识
分区功能能够将表 索引或索引组织表进一步细分为段 这些数据库对象的段叫做分区 每个分区有自己的名称 还可以选择自己的存储特性 从数据库管理员的角度来看 一个分区后的对象具有多个段 这些段既可进行集体管理 也可单独管理 这就使数据库管理员在管理分区后的对象时有相当大的灵活性 但是 从应用程序的角度来看 分区后的表与非分区表完全相同 使用 SQL DML 命令访问分区后的表时 无需任何修改
表的分区是通过 分区键 来实现的 分区键指的是一些列 这些列决定了某一行所在的分区 Oracle 数据库 g 提供了六项技术用于对表进行分区
范围分区
每个分区都由一个分区键值范围指定(对于一个以日期列作为分区键的表 年 月 分区包含分区键值为从 年 月 日 到 年 月 日 的行)
列表分区
每个分区都由一个分区键值列表指定(对于一个地区列作为分区键的表 北美 分区可能包含值 加拿大 美国 和 墨西哥 )
散列分区
将散列算法用于分区键来确定指定行所在的分区
组合范围散列分区
范围和散列分区技术的组合 通过该组合 首先对表进行范围分区 然后针对每个单独的范围分区再使用散列分区技术进一步细分 索引组织表只能进行范围分区
组合范围列表分区
范围和列表分区技术的组合 通过该组合 首先对表进行范围分区 然后针对每个单独的范围分区再使用列表分区技术进一步细分 索引组织表可以按范围 列表或散列进行分区
Oracle 数据库 g 还提供了三种类型的分区索引
本地索引
本地索引是其分区方式与其所在基础表的分区方式一模一样的索引 本地索引的每个分区仅对应于其所在基础表的一个分区
全局分区索引
全局分区索引是使用不同于其所在表的分区键进行分区的索引 其所在表可以是分区表或非分区表 全局分区的索引可以使用范围或散列分区进行分区 例如 某个表可以按月份进行范围分区 因此具有十二个分区 而该表上的索引则可以使用不同的分区键进行范围分区 从而具有不同的分区数量
全局非分区索引
全局非分区索引基本上和非分区表的索引一样 索引结构是不分区的
Oracle 提供了一系列丰富的技术 可用于对表 索引和索引组织表进行分区 因此可以针对任何业务环境中的任何应用程序进行最佳的分区 Oracle 还提供一套完整的 SQL 命令 用于管理分区表 其中包括添加新分区 删除分区 分拆分区以及合并分区的命令
用分区功能提高可管理性
通过 Oracle 分区功能 可将表和索引分成更多 更小的可管理单元 从而使数据库管理员能以 化整为零 个个击破 的方式管理数据
使用分区功能 维护 *** 作可集中于表的特定部分 例如 数据库管理员可以只对表的一部分做备份 而不必对整个表做备份 对整个数据库对象的维护 *** 作 可以在每个分区的基础上进行 从而将维护工作分解成更容易管理的小块
利用分区功能提高可管理性的一个典型用法是支持数据仓库中的 滚动视窗 加载进程 假设数据库管理员每周向表中加载新数据 可以对该表进行范围分区 使每个分区包含一周的数据 这样加载进程只是简单地添加新的分区 添加一个分区的 *** 作比修改整个表效率高很多 因为 DBA 不需要修改任何其他分区
用分区功能提高性能
由于限制了所检查或 *** 作的数据数量 同时支持并行任务执行 Oracle 分区功能实现了性能上增益 这些特性包括
分区修整
分区修整是用分区功能提高性能的最简单最有价值的手段 分区修整常常能够将查询性能提高几个数量级 例如 假设某个应用程序包含一个存储订单历史记录的 Orders 表 并且此表已按周分区 查询一周的订单只需访问该订单表的一个分区 如果该订单表包含两年的历史记录 这个查询只需要访问一个分区而不是一百零四个 该查询的执行速度因为分区修整而有可能快一百倍 分区修整能与所有其他 Oracle 性能特性协作 Oracle 能将分区修整功能与任何索引技术 联接技术或并行访问方法结合使用
分区智能联接
分区功能可以通过称为分区智能联接的技术提高多表联接的性能 当两个表要联接在一起 而且每个表都用联接键来分区时 就可以使用分区智能联接 分区智能联接将大型联接分解成较小的发生在各个分区间的联接 从而用较少的时间完成全部联接 这就给串行和并行的执行都能带来显著的性能改善
用分区功能提高可用性
分区的数据库对象具有分区独立性 该分区独立性特点可能是高可用性战略的一个重要部分 例如 如果分区表的一个分区不能用 但该表的所有其他分区仍然保持在线并可用 那么这个应用可以继续针对该分区表执行查询和事务处理 只要不是访问不可用的分区 数据库 *** 作仍然能够成功运行
数据库管理员可以指定各分区存放在不同的表空间里 从而让管理员隔离其它表分区针对单个分区进行备份与恢复 *** 作 还有 分区功能可以减少计划停机时间 由于分区功能改善了性能 使数据库管理员能用相对较少的时间完成大型数据库对象的维护工作
未来发展方向
自从引入分区技术以来 Oracle 公司在每次推出重要版本时都会增加新的分区方法 Oracle 引入了范围分区功能 Oracle i 引入了散列和组合范围散列分区功能 Oracle i 引入了列表分区功能 在最新版本 Oracle 数据库 g 中 则增强了用于索引组织表和全局分区索引的分区策略 并且扩展了其用于所有分区维护 *** 作的并发索引维护功能 Oracle 公司致力于不断完善分区技术 确保满足所有的业务需求
结论
lishixinzhi/Article/program/Oracle/201311/16823
以上就是关于分区表和分区视图是什么概念,一般是在什么情况下使用,有啥好处全部的内容,包括:分区表和分区视图是什么概念,一般是在什么情况下使用,有啥好处、Oracle分区功能提高应用程序性能、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)