查看: 2219|回复: 5

关于分区表的使用

[复制链接]
论坛徽章:
0
跳转到指定楼层
1#
发表于 2003-1-9 17:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
分区表除了建立比较麻烦,在维护上有么特别的要求(比如什么样的操作对他是无效的),也就是说分区表的使用有哪些局限性,望大虾赐教
论坛徽章:
164
秀才
日期:2015-11-11 09:58:34
2#
发表于 2003-1-9 17:38 | 只看该作者
首页>>资讯中心>> 数据库  2001-06-15 09:26:10   来源: jiafangyifang.com    



创建和使用分区的表



在ORACLE里如果遇到特别大的表,可以使用分区的表来改变其应用程序的性能。

以system身份登陆数据库,查看 v$option视图,如果其中Partition为TRUE,则支持分区功能;否则不支持。Partition有基于范围、哈希、综和三种类型。我们用的比较多的是按范围分区的表。

我们以一个2001年开始使用的留言版做例子讲述分区表的创建和使用:

1 、以system 身份创建独立的表空间(大小可以根据数据量的多少而定)

create tablespace g_2000q4 datafile '/home/oradata/oradata/test/g_2000q4.dbf' size 50M default storage (initial 100k next 100k minextents 1 maxextents unlimited pctincrease 1);

create tablespace g_2001q1 datafile '/home/oradata/oradata/test/g_2001q1.dbf' size 50M default storage (initial 100k next 100k minextents 1 maxextents unlimited pctincrease 1);

create tablespace g_2001q2 datafile '/home/oradata/oradata/test/g_2001q2.dbf' size 50M default storage (initial 100k next 100k minextents 1 maxextents unlimited pctincrease 1);

2 、用EXPORT工具把旧数据备份在guestbook.dmp中

把原来的guestbook表改名

alter table guestbook rename to guestbookold;

以guestbook 身份创建分区的表

create table guestbook(
id number(16) primary key,
username varchar2(64),
sex varchar2(2),
email varchar2(256),
expression varchar2(128),
content varchar2(4000),
time date,
ip varchar2(64)
)
partition by range (time)
(partition g_2000q4 values less than (to_date('2001-01-01','yyyy-mm-dd'))
tablespace g_2000q4
storage(initial 100k next 100k minextents 1 maxextents unlimited pctincrease 0),
partition g_2001q1 values less than (to_date('2001-04-01','yyyy-mm-dd'))
tablespace g_2001q1
storage(initial 100k next 100k minextents 1 maxextents unlimited pctincrease 0),
partition g_2001q2 values less than (to_date('2001-07-01','yyyy-mm-dd'))
tablespace g_2001q2
storage(initial 100k next 100k minextents 1 maxextents unlimited pctincrease 0)
);

(说明:分区的名称可以和表空间的名称不一致。这里是每个季度做一个分区,当然也可以每个月做一个分区)

3、IMPORT导入数据,参数ignore=y

4、分区表的扩容:

到了2001 年下半年,建立新的表空间:

create tablespace g_2001q3 datafile '/home/oradata/oradata/test/g_2001q3.dbf' size 50m default storage (initial 100k next 100k minextents 1 maxextents unlimited pctincrease 1);

为表添加新分区和表空间:

alter table guestbook add partition g_2001q3
values less than (to_date('2001-10-01','yyyy-mm-dd')
tablespace g_2001q3
storage(initial 100k next 100k minextents 1 maxextents unlimited pctincrease 0);

5、删除不必要的分区

将2000年的数据备份(备份方法见 6、EXPORT 分区),将2000年的分区删除。

alter table guestbook drop partion g_2000q4;

删除物理文件

%rm /home/oradata/oradata/test/g_2000q4.dbf

6、EXPORT 分区:

% exp guestbook/guestbook_password tables=guestbook:g_2000q4 rows=Y file=g_2000q4.dmp

7、IMPORT分区:

例如在2001 年,用户要查看2000 年的数据,先创建表空间

create tablespace g_2000q4 datafile '/home/oradata/oradata/test/g_2000q4.dbf' size 50m default storage (initial 100k next 100k minextents 1 maxextents unlimited pctincrease 1);

为表添加新分区和表空间:

alter table guestbook add partition g_2000q4
values less than (to_date('2001-01-01','yyyy-mm-dd')
tablespace g_2001q3
storage(initial 100k next 100k minextents 1 maxextents unlimited pctincrease 0);

导入数据

%imp guestbook/guestbook_password file=g_2000q4.dmp tables=(guestbook:g_2000q4) ignore=y

(说明:如果不指明导入的分区,imp会自动按分区定义的范围装载数据)

使用道具 举报

回复
论坛徽章:
0
3#
 楼主| 发表于 2003-1-9 20:18 | 只看该作者
斑竹非常感谢您耐心的讲解,我感到收益非浅,顺便我还想问一下分区表有没有什么局限性,比如使用了分区后oracle的其他操作对他不能进行,或是什么操作对分区表来说要小心

使用道具 举报

回复
论坛徽章:
60
2007年度最佳版主
日期:2008-04-03 16:46:15现任管理团队成员
日期:2011-05-07 01:45:08双黄蛋
日期:2011-06-15 17:03:34ITPUB十周年纪念徽章
日期:2011-11-01 16:19:412012新春纪念徽章
日期:2012-01-04 11:49:542012新春纪念徽章
日期:2012-02-13 15:13:202012新春纪念徽章
日期:2012-02-13 15:13:202012新春纪念徽章
日期:2012-02-13 15:13:202012新春纪念徽章
日期:2012-02-13 15:13:202012新春纪念徽章
日期:2012-02-13 15:13:20
4#
发表于 2003-1-9 20:42 | 只看该作者
分区表的出现对Oracle面对数据仓库类似的大型环境有了很好的存储解决方案.

Oracle对 表/表上索引/物化视图以及物化视图上的索引提供支持.

Oracle不支持 簇表(clustered table) 或者簇表上的索引的分区.

分区对象的所有分区的物理属性要求同样的块大小.

还有其他的细微之处,谁来补充?

使用道具 举报

回复
论坛徽章:
0
5#
 楼主| 发表于 2003-1-10 09:01 | 只看该作者
谢谢FENG的解答

使用道具 举报

回复
论坛徽章:
0
6#
 楼主| 发表于 2003-1-11 10:46 | 只看该作者
Feng ,能不能讲讲关于簇表(cluster table)以及它的使用

使用道具 举报

回复

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

TOP技术积分榜 社区积分榜 徽章 团队 统计 知识索引树 积分竞拍 文本模式 帮助
  ITPUB首页 | ITPUB论坛 | 数据库技术 | 企业信息化 | 开发技术 | 微软技术 | 软件工程与项目管理 | IBM技术园地 | 行业纵向讨论 | IT招聘 | IT文档
  ChinaUnix | ChinaUnix博客 | ChinaUnix论坛
CopyRight 1999-2011 itpub.net All Right Reserved. 北京盛拓优讯信息技术有限公司版权所有 联系我们 未成年人举报专区 
京ICP备16024965号-8  北京市公安局海淀分局网监中心备案编号:11010802021510 广播电视节目制作经营许可证:编号(京)字第1149号
  
快速回复 返回顶部 返回列表