A. Oracle分区功能提高应用程序性能
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 公司致力于不断完善分区技术 确保满足所有的业务需求
结论
lishixin/Article/program/Oracle/201311/16823
B. bcr是什么意思
BCR是Base Case Rection的缩写。
BCR是一个特定的术语,在计算机科学和软件开发中常被提及。具体来说:
1. 定义与含义:BCR即Base Case Rection,是软件开发和程序设计中用于描述一种策略或方法的术语。在软件开发中,Base Case指的是一个特定问题规模最小的情况,通常是递归算法中的基本情况。Rection则意味着缩小问题的规模。因此,BCR可以理解为通过逐步缩小问题规模来解决复杂问题的一种方法。特别是在处理大型项目或复杂问题时,将大问题分解为若干小问题来解决是一种有效的策略。每一个小问题的解决都有助于减少基础情况的数量,直至问题解决完毕。
2. 应用场景:在软件开发中,特别是在解决涉及复杂数据结构和算法的问题时,BCR经常作为关键的技术手段被采用。特别是在解决一些涉及到递归的问题时,通过将问题分解为更小的子问题并逐步解决这些子问题,最终可以实现对复杂问题的简化解决。在这个过程中,每一个小的子问题都相当于一个基础案例,通过逐步解决这些基础案例,最终达到解决问题的目的。在这个过程中,“rection”指的是缩小问题的规模或复杂度的过程。通过这种方式,不仅可以提高软件的效率,还能使得软件设计更加清晰、易于理解和维护。在这个过程中使用的技术和方法即为BCR方法的应用。通过这样的方式解决问题可以有效地提升软件性能,并保证软件设计简洁易懂、易于维护。同时,这种策略对于提升代码的可读性和可维护性也有着重要作用。
以上就是对BCR的详细解释。希望这个回答能够帮助你理解BCR的含义和应用场景。