Oracle-分区表案例

Oracle-分区表案例

Oracle-分区表案例

Oracle数据库开发了解分区表
分区就是将一个非常大的表或者索引物理地分解为多个较小的 可独立管理的部分.
分区表或索引在逻辑上是一个表或一个索引,但物理上是由多个物理分区组成的.
分区功能通过改善可管理性 性能 可用性,为各种应用系统带来了极大的好处.
分区功能的好处:
1.增强数据可用性:如果表的一个分区因故障或者维护而不能使用时,表的其余分区仍是可用的;
2.维护方便:独立管理多个分区,比维护单个大表要轻松;
3.均衡I/O:可以把不同分区映射到磁盘以平衡I/O,显著改善性能;
4.改善查询性能:对已分区对象的某些查询可以运行更快,因为搜索仅限于关心的分区;

分区表有哪些??
Oracle 11g 提供6种表分区方法:范围分区(range) 散列分区(hash) 列表分区(list)
符合分区 间隔分区 引用分区.


按表中某个列值的范围进行分区,根据该列的值决定将数据存储在哪个分区上.

创建范围分区需注意以下几点:
1.指明分区方法,分区列,和分区描述
2.每一个分区都有values less than子句
3.在最高分区中定义maxvalue,这个maxvalue值高区其他分区中的任何键值.
例:创建范围分区

create table range_orders
(order_id varchar2(10) constraint OR_PK primary key
,order_date date default sysdate
,qty integer
,payterms varchar2(10)
,book_id number(6)
)
partition by range (order_date)
(partition p1 values less than (to_date(‘20140331′,’yyyymmdd’)) tablespace user01,
partition p2 values less than (to_date(‘20140430′,’yyyymmdd’)) tablespace user02,
partition p3 values less than (to_date(‘20140531′,’yyyymmdd’)) tablespace user03
)
;

SQL> insert into range_orders values (‘10001’,to_date(‘20140321′,’yyyymmdd’),1,’payterm_1′,110345);
1 row inserted
SQL> insert into range_orders values (‘10002’,to_date(‘20140421′,’yyyymmdd’),1,’payterm_2′,110745);
1 row inserted
SQL> insert into range_orders values (‘10003’,to_date(‘20140521′,’yyyymmdd’),1,’payterm_3′,110945);
1 row inserted

SQL> commit;
Commit complete

SQL> select rowid,r.* from range_orders r;
ROWID ORDER_ID ORDER_DATE QTY PAYTERMS BOOK_ID
—————— ———- ———– —- ———- ——-
AAADwpAAGAAAACFAAA 10001 2014/3/21 1 payterm_1 110345
AAADwqAAHAAAACFAAA 10002 2014/4/21 1 payterm_2 110745
AAADwrAAIAAAACFAAA 10003 2014/5/21 1 payterm_3 110945

可以看到AAG,AAH,AAI 分别代表了三条数据的文件号是6,7,8
备注:这个地方可以看下http://blog.itpub.net/28929558/viewspace-1150766/ 了解rowid
验证下

SQL> select x.FILE#,x.NAME from v$datafile x;

FILE# NAME
———- —————————————-
1 D:\ORACLE\ORADATA\CRISS_DB\SYSTEM01.DBF
2 D:\ORACLE\ORADATA\CRISS_DB\SYSAUX01.DBF
3 D:\ORACLE\ORADATA\CRISS_DB\UNDOTBS01.DBF
4 D:\ORACLE\ORADATA\CRISS_DB\USERS01.DBF
5 D:\ORACLE\ORADATA\CRISS_DB\TEST01.DBF
6 D:\ORACLE\ORADATA\CRISS_DB\USER01.DBF
7 D:\ORACLE\ORADATA\CRISS_DB\USER02.DBF
8 D:\ORACLE\ORADATA\CRISS_DB\USER03.DBF

8 rows selected


散列分区指一个或多个列上应用一个散列函数,数根据该散列值存放在不同的分区中.
通过散列分区,可以将数据比较均匀地分布到各个分区中.

例:创建散列分区表

SQL> create table hash_orders

(order_id varchar2(10) constraint HOR_PK primary key
,order_date date default sysdate
,qty integer
,payterms varchar2(10)
,book_id number(6)
)
partition by hash(order_id)
( partition hash_p1 tablespace user01
,partition hash_p2 tablespace user02
);

 

Table created

SQL> insert into hash_orders select * from range_orders;

3 rows inserted

 

SQL> select rowid,h.* from hash_orders h;

ROWID ORDER_ID ORDER_DATE QTY PAYTERMS BOOK_ID
—————— ———- —————– ———- ——-
AAADyIAAGAAAACNAAA 10002 2014/4/21 1 payterm_2 110745
AAADyIAAGAAAACNAAB 10003 2014/5/21 1 payterm_3 110945
AAADyJAAHAAAACNAAA 10001 2014/3/21 1 payterm_1 110345

 

继续: http://blog.csdn.net/woshimyc/article/details/73289798

 

-end-

好烂啊有点差凑合看看还不错很精彩 (No Ratings Yet)
Loading...
267 views

发表评论

电子邮件地址不会被公开。 必填项已用*标注

跳至工具栏