简捷的Oracle增加表分区研究

Oracle增加表分区(add partition)是常用的Oracle分区常用的操作。下面就简单的介绍下Oracle增加表分区的知识要点。

成都创新互联主营彝良网站建设的网络公司,主营网站建设方案,成都App定制开发,彝良h5重庆小程序开发公司搭建,彝良网站营销推广欢迎彝良等地区企业咨询

增加表分区适应于所有的分区形式,其语法是alter table tbname add partition .....

但是,需要注意对于像list,range这种存在范围值的分区,所要增加的分区值必须要大于当前分区中的最大值(如果当前存在maxvalue或default的分区,add partition会报错,这种情况只能使用split,后面会讲到),hash分区则无此限制。

例如:

 
 
 
  1. JSSWEB> create table t_partition_range (id number,name varchar2(50))  
  2.    partition by range(id)(  
  3.    partition t_range_p1 values less than (10) tablespace tbspart01,  
  4.    partition t_range_p2 values less than (20) tablespace tbspart02,  
  5.    partition t_range_p3 values less than (30) tablespace tbspart03  
  6.     );  

表已创建。

 
 
 
  1. JSSWEB> alter table t_partition_range  
  2. add partition t_range_p4 values less than(40);  
  3.  

表已更改。
Hash和list的语法与上类似,这里不再举例。

注意:

1、对于hash分区,当你执行add partition操作的时候,oracle会自动选择一个分区,并重新分配部分记录到新建的分区,这也意味着有可能带来一些IO操作。

2、执行alter table时未指定update indexes子句:
如果是range/list分区,其local索引和global索引不会受影响;
如果是hash分区,新加分区及有数据移动的分区的local索引和glocal索引会被置为unuseable,需要重新编译。

3、复合分区完全适用上述所述规则。

本文就Oracle增加表分区来自[Svn中文网]转发请保留本站地址:http://www.svn8.com/sql/Oracle/2009111312912.html

【编辑推荐】

  1. 修改Oracle存储过程所需代码
  2. 对Oracle存储过程的总结
  3. 实现Oracle存储过程的实际应用的代码 
  4. 深入高性能的Oracle动态SQL开发 
  5. Oracle SQL的优化规则解析 

本文名称:简捷的Oracle增加表分区研究
当前路径:http://www.shufengxianlan.com/qtweb/news28/187928.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联