热门标签 | HotTags
当前位置:  开发笔记 > 人工智能 > 正文

Oracle分区表的使用和管理

Oracle分区表的使用和管理在某些场合会使用非常大的表,比如人口信息统计表。如果一个表很大,就会降低查询的速度,并增加管理的难度。一旦发生磁盘损坏,可能整个表的数据就会丢失,恢复比较困难。根据...SyntaxHighlighter.all();
Oracle分区表的使用和管理
 
         在某些场合会使用非常大的表,比如人口信息统计表。如果一个表很大,就会降低查询的速度,并增加管理的难度。一旦发生磁盘损坏,可能整个表的数据就会丢失,恢复比较困难。根据这一情况,可以创建分区表,把一个大表分成几个区(小段),对数据的操作和管理都可以针对分区进行,这样就可以提高数据库的运行效率。分区可以存在于不同的表空间上,提高了数据的可用性。
1.使用分区的优点:
    *增强可用性:如果表的某个分区出现故障,表在其他分区的数据仍然可用;
    *维护方便:如果表的某个分区出现故障,需要修复数据,只修复该分区即可;
    *均衡I/O:可以把不同的分区映射到磁盘以平衡I/O,改善整个系统性能;
  *改善查询性能:对分区对象的查询可以仅搜索自己关心的分区,提高检索速度
2.表分区的依据
分区的依据可以是一列或多列的值,这一列或多列称为分区关键字或分区列。所有分区的逻辑属性是一样的(列名、数据类型、约束条件等),但每个分区可以有自己的物理属性(表空间、存储参数等)。
分区有四种:范围分区、哈希分区、列表分区和组合分区。
范围分区:根据分区关键字值的范围建立分区,将记录存放到列值所在的range分区中。比如,根据时间建立分区。
为各个分区建立独立的表空间
create tablespace test_space001 datafile'd:\tbs001.dbf' size20M;
create tablespace test_space002 datafile'd:\tbs002.dbf' size20M;
create tablespace test_space003 datafile'd:\tbs003.dbf' size20M;
建立分区表:
Create table range_example(
Range_key_column  date,
Dat    varchar2(20),
Id  integer
)
Partition by range(range_key_column)
(
Partition part01 values less than(to_date(‘2013-8-28’,’yyyy-mm-dd’)) tablespace test_space01,
Partition part02 values less  than(to_date(‘2013-9-28’,’yyyy-mm-dd’)) tablespace test_space02
Partition part03 values less  than(maxvalue)) tablespace test_space03
)
如果某些记录暂时无法预测范围,可以创建maxvalue分区,所有不在指定范围内的记录都会被存储到Maxvalue所在分区中
在表分区上进行查询
Select * from  range_example partition(part01);
 
哈希分区:对于那些无法有效划分范围的表,在分区列上使用HASH算法进行分区,这样对于提高性能还是会有一定的帮助。hash分区会将表中的数据平均分配到你指定的几个分区中,列所在分区是依据分区列的hash值自动分配,因此你并不能控制也不知道哪条记录会被放到哪个分区.
create table test
(
transaction_id number primary key,
item_id number(8) not null
)
partition by hash(transaction_id)
(
partition part_01 tablespace tablespace01,
partition part_02 tablespace tablespace02,
partition part_03 tablespace tablespace03
);
 
列表分区:根据预先定义好的分区键数值确定记录被分配到哪个分区。List分区也需要指定列的值,其分区值必须明确指定,该分区列只能有一个,不能像range或者hash分区那样同时指定多个列做为分区依赖列,但它的单个分区对应值可以是多个。 在分区时必须确定分区列可能存在的值,一旦插入的列值不在分区范围内,则插入/更新就会失败,因此通常建议使用list分区时,要创建一个default分区存储那些不在指定范围内的记录,类似range分区中的maxvalue分区。
create table custaddr
(
  id                     varchar2(15 byte)   not null,
  areacode      varchar2(4 byte)
 )
partition by list (areacode)
( partition t_list025 values ('025'),  
 partition t_list372 values ('372') , 
 partition t_list510 values ('510'), 
partition p_other values (default)
)
 
组合分区:如果某表按照某列分区之后,仍然较大,或者是一些其它的需求,还可以通过分区内再建子分区的方式将分区再分区,即组合分区的方式。 组合分区在10g中有两种:range-hash,range-list。注意顺序,根分区只能是range分区,子分区可以是hash分区或list分区。在Oracle 11g中,组合分区功能又增加了range-range,list-range,list-list,list-hash,并且 11g里面还支持Interval分区和虚拟列分区。
语法:
PARTITION BY RANGE (column_name1)  
SUBPARTITION BY HASH (column_name2)  
SUBPARTITIONS number_of_partitions  
(      
  PARTITION part1 VALUE LESS THAN(range1),  
  PARTITION part2 VALUE LESS THAN(range2),  
  ...  
  PARTITION partN VALUE LESS THAN(MAXVALUE)  
);  
 
应用:对时间字段按范围进行分区后每个分区的记录数仍然很多,可以按很少重复的列(月份)进行hash分区,这个可以使子分区的记录数目比较平衡
CREATE TABLE SALES  
(  
    PRODUCT_ID VARCHAR2 (5),  
    SALES_DATE DATE NOT NULL,  
    SALES_COST NUMBER (10)  
)      
PARTITION BY RANGE (SALES_DATE)  
SUBPARTITION BY HASH (PRODUCT_ID)  
  subpartitions 3 store in (tablespace01,tablespace02,tablespace03)    
(  
    PARTITION S1 VALUES LESS THAN (TO_DATE(‘01/4月/2011','DD/MON/YYYY')),  
    PARTITION S2 VALUES LESS THAN (TO_DATE(‘01/7月/2011','DD/MON/YYYY')),  
    PARTITION S3 VALUES LESS THAN (MAXVALUE)  
);  
 
 

推荐阅读
  • 深度学习理论解析与理解
    梯度方向指示函数值增加的方向,由各轴方向的偏导数综合而成,其模长表示函数值变化的速率。本文详细探讨了导数、偏导数、梯度等概念,并结合Softmax函数、卷积神经网络(CNN)中的卷积计算、权值共享及池化操作进行了深入分析。 ... [详细]
  • 机器学习中的相似度度量与模型优化
    本文探讨了机器学习中常见的相似度度量方法,包括余弦相似度、欧氏距离和马氏距离,并详细介绍了如何通过选择合适的模型复杂度和正则化来提高模型的泛化能力。此外,文章还涵盖了模型评估的各种方法和指标,以及不同分类器的工作原理和应用场景。 ... [详细]
  • 本实验主要探讨了二叉排序树(BST)的基本操作,包括创建、查找和删除节点。通过具体实例和代码实现,详细介绍了如何使用递归和非递归方法进行关键字查找,并展示了删除特定节点后的树结构变化。 ... [详细]
  • MATLAB实现n条线段交点计算
    本文介绍了一种通过逐对比较线段来求解交点的简单算法。此外,还提到了一种基于排序的方法,但该方法较为复杂,尚未完全理解。文中详细描述了如何根据线段端点求交点,并判断交点是否在线段上。 ... [详细]
  • 高效解决应用崩溃问题!友盟新版错误分析工具全面升级
    友盟推出的最新版错误分析工具,专为移动开发者设计,提供强大的Crash收集与分析功能。该工具能够实时监控App运行状态,快速发现并修复错误,显著提升应用的稳定性和用户体验。 ... [详细]
  • 从零开始构建完整手机站:Vue CLI 3 实战指南(第一部分)
    本系列教程将引导您使用 Vue CLI 3 构建一个功能齐全的移动应用。我们将深入探讨项目中涉及的每一个知识点,并确保这些内容与实际工作中的需求紧密结合。 ... [详细]
  • 帝国CMS多图上传插件详解及使用指南
    本文介绍了一款用于帝国CMS的多图上传插件,该插件通过Flash技术实现批量图片上传功能,显著提升了多图上传效率。文章详细说明了插件的安装、配置和使用方法。 ... [详细]
  • 解决Windows 10无法正确加载ICA文件的问题:设置Citrix Receiver为默认打开程序
    当在Windows 10系统中遇到无法正确加载ICA文件的情况时,可以通过下载并安装Citrix Receiver,并将其设置为ICA文件的默认打开方式来解决问题。具体操作步骤包括找到ICA文件,选择合适的打开程序路径(通常是C:\Program Files (x86)\Citrix\ICA Client\wfcrun32.exe),并确保该程序被设为始终使用。 ... [详细]
  • 本教程涵盖OpenGL基础操作及直线光栅化技术,包括点的绘制、简单图形绘制、直线绘制以及DDA和中点画线算法。通过逐步实践,帮助读者掌握OpenGL的基本使用方法。 ... [详细]
  • 图数据库中的知识表示与推理机制
    本文探讨了图数据库及其技术生态系统在知识表示和推理问题上的应用。通过理解图数据结构,尤其是属性图的特性,可以为复杂的数据关系提供高效且优雅的解决方案。我们将详细介绍属性图的基本概念、对象建模、概念建模以及自动推理的过程,并结合实际代码示例进行说明。 ... [详细]
  • 获取计算机硬盘序列号的方法与实现
    本文介绍了如何通过编程方法获取计算机硬盘的唯一标识符(序列号),并提供了详细的代码示例和解释。此外,还涵盖了如何使用这些信息进行身份验证或注册保护。 ... [详细]
  • 本文详细介绍了 React 中的两个重要 Hook 函数:useState 和 useEffect。通过具体示例,解释了如何使用它们来管理组件状态和处理副作用。 ... [详细]
  • libsodium 1.0.15 发布:引入重大不兼容更新
    最新发布的 libsodium 1.0.15 版本带来了若干不兼容的变更,其中包括默认密码散列算法的更改和其他重要调整。 ... [详细]
  • 本文总结了涡喷发动机动平衡的几种有效方法,探讨了不同传感器和软件工具的应用,旨在帮助爱好者和工程师更好地理解和实现动平衡调整,确保发动机高效稳定运行。 ... [详细]
  • 汇编语言等号伪指令解析:探究其陡峭的学习曲线
    汇编语言以其独特的特性和复杂的语法结构,一直被认为是编程领域中学习难度较高的语言之一。本文将探讨汇编语言中的等号伪指令及其对初学者带来的挑战,并结合社区反馈分析其学习曲线。 ... [详细]
author-avatar
姜亦珊边_135
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有