system partition table
转载内容
摘录部分我的笔记的中doc,和大家一起感受Oracle 11g在分区方面的增强--System Partitioning
系统分区的特点
●系统分区与其他分区相比,一个最根本的区别就是不需要指定分区KEY值
●数据会进入哪个分区由应用程序决定,实际上也就是由SQL来决定,在Insert语句中可以指定插入哪个分区
●因为System Partitioning分区表没有分区字段,所以一般分区表的performance benefits对System Partitioning分区表不再适用(包括分区表智能裁剪和智能联接)
●对于按“系统”方法进行分区的表, 必须对 DML 使用分区扩展名或绑定变量
●记录放在哪个分区与记录没有任何关系,同样的记录可以存放到不同的分区中 ●The following operations are supported for system partitioned tables: Partition maintenance operations and other DDLs (See exceptions below) Creation of local indexes. Creation of local bitmapped indexes. Creation of global indexes. All DML operations. ●insert 操作支持三种写法
INSERT with partition extended syntax: insert into <base_table> partition (<partition_name|dataobj_to_partition(table_name,:data_object_id)>)
其中data_object_id通过dba_objects视图中获取
参考文档:<Oracle Database Data Cartridge Developer's Guide> 11g Realses 1(11.1) Part Number B28425-01
●Because of the peculiar requirements of system partitioning, the following operations are not supported for system partitioning: Unique local indexes are not supported because they require a partitioning key. CREATE TABLE AS SELECT(不能通过CTAS创建System Partitioning表) Since there is no partitioning method, it is not possible to distribute rows to partitions. Instead the user should first create the table and then insert rows into each partition. INSERT INTO <tabname> AS <subquery> SPLIT PARTITION operations
说明
或许我们对Oracle提供的这个新特性的实际用途使用很少,但不难看出这确实是一个非常人性化的变革,所以我们也不得不认真、仔细的认识并研究他。或许将来我们有一个这样的需求:
假设有一个无法使用任何逻辑方法进行分区的表,结果将是一个巨大的、单一的表。不难想象这将导致需要扩展的索引维护和其他操作问题的出现。于是,开发那边可以提出一个这样的要求:他们可以通过某种智能算法写入分区,通过应用来控制特定的记录写入到某个分区,而对DBA来说,就只需要定义一个system partitiion table即可。
示例一:System Partitioning初体验
Connected to Oracle Database 11g Enterprise Edition Release 11.1.0.6.0
Connected as study SQL> create table sys_part_test
2 (
3 region number(4),
4 recdate date
5 )
6 partition by system
7 (
8 partition p1,
9 partition p2,
10 partition p3,
11 partition p4
12 ); Table created SQL> insert into sys_part_test partition (p1) values(531,sysdate);
1 row inserted SQL> insert into sys_part_test partition (p2) values(532,sysdate);
1 row inserted SQL> insert into sys_part_test partition (p3) values(533,sysdate);
1 row inserted SQL> insert into sys_part_test partition (p4) values(534,sysdate);
1 row inserted SQL> commit;
Commit complete SQL> select * from sys_part_test; REGION RECDATE
------ -----------
531 2007-12-14
532 2007-12-14
533 2007-12-14
534 2007-12-14 SQL> insert into sys_part_test partition (p1) select * from sys_part_test partition (p4);
1 row inserted SQL> commit;
Commit complete SQL> select * from sys_part_test partition (p1);
REGION RECDATE
------ -----------
531 2007-12-14
534 2007-12-14 SQL> select * from sys_part_test partition (p2);
REGION RECDATE
------ -----------
532 2007-12-14 SQL> select * from sys_part_test partition (p3);
REGION RECDATE
------ -----------
533 2007-12-14 SQL> select * from sys_part_test partition (p4);
REGION RECDATE
------ -----------
534 2007-12-14 SQL> select *from sys_part_test; REGION RECDATE
---------- -------------------
531 2007-12-14 17:21:13
534 2007-12-14 17:21:32
532 2007-12-14 17:21:20
533 2007-12-14 17:21:26
534 2007-12-14 17:21:32 SQL> update sys_part_test set recdate=sysdate where region=533;
已更新 1 行。 SQL> select *from sys_part_test; REGION RECDATE
---------- -------------------
531 2007-12-14 17:21:13
534 2007-12-14 17:21:32
532 2007-12-14 17:21:20
533 2007-12-14 17:27:19
534 2007-12-14 17:21:32 SQL> delete from sys_part_test partition(p4);
已删除 1 行。 SQL> select *from sys_part_test; REGION RECDATE
---------- -------------------
531 2007-12-14 17:21:13
534 2007-12-14 17:21:32
532 2007-12-14 17:21:20
533 2007-12-14 17:27:19
SQL>
示例二:System Partitioning Insert三种方法体验
D:>sqlplus study/study@ora11g SQL*Plus: Release 11.1.0.6.0 - Production on 星期六 12月 15 10:41:13 2007 Copyright (c) 1982, 2007, Oracle. All rights reserved. 连接到:
Oracle Database 11g Enterprise Edition Release 11.1.0.6.0 - Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options SQL> create table sys_part_test
2 (
3 region number(4),
4 recdate date
5 )
6 partition by system
7 (
8 partition p1,
9 partition p2,
10 partition p3,
11 partition p4
12 ); 表已创建。 SQL> insert into sys_part_test partition (p1) values (531,sysdate); --方法一,指定partition_name
已创建 1 行。 SQL> commit;
提交完成。 SQL> select * from sys_part_test; REGION RECDATE
---------- -------------------
531 2007-12-15 10:41:43 SQL> select object_name,subobject_name,object_id,data_object_id,object_type
2 from user_objects
3 where object_name='SYS_PART_TEST'; OBJECT_NAME SUBOBJECT_NAME OBJECT_ID DATA_OBJECT_ID OBJECT_TYPE
-------------- ----------------- ----------- -------------- ---------------
SYS_PART_TEST 69632 TABLE
SYS_PART_TEST P1 69633 69633 TABLE PARTITION
SYS_PART_TEST P2 69634 69634 TABLE PARTITION
SYS_PART_TEST P3 69635 69635 TABLE PARTITION
SYS_PART_TEST P4 69636 69636 TABLE PARTITION SQL> insert into sys_part_test partition(dataobj_to_partition(sys_part_test,)) values (532,sysdate);
已创建 1 行。 --方法二,通过data object id SQL> commit;
提交完成。 SQL> select *from sys_part_test; REGION RECDATE
---------- -------------------
531 2007-12-15 10:41:43
532 2007-12-15 10:43:44 SQL> select *from sys_part_test partition (p2); REGION RECDATE
---------- -------------------
532 2007-12-15 10:43:44 SQL> var p_obj number;
SQL> exec :p_obj:=69635 PL/SQL 过程已成功完成。 --如下为方法三,通过data object id但使用bind var SQL> insert into sys_part_test partition(dataobj_to_partition(sys_part_test,:p_obj)) values (533,sysdate);
已创建 1 行。 SQL> insert into sys_part_test partition(dataobj_to_partition(sys_part_test,:p_obj)) values (533,sysdate);
已创建 1 行。 SQL> commit;
提交完成。 SQL> select * from sys_part_test; REGION RECDATE
---------- -------------------
531 2007-12-15 10:41:43
532 2007-12-15 10:43:44
533 2007-12-15 10:45:19
533 2007-12-15 10:45:21 SQL> select * from sys_part_test partition (p3); REGION RECDATE
---------- -------------------
533 2007-12-15 10:45:19
533 2007-12-15 10:45:21 SQL> select * from sys_part_test partition (p2); REGION RECDATE
---------- -------------------
532 2007-12-15 10:43:44 SQL> select * from sys_part_test partition (p1); REGION RECDATE
---------- -------------------
531 2007-12-15 10:41:43 SQL>
...
system partition table的更多相关文章
- WARNING: Re-reading the partition table failed with error 16: Device or resource busy.
在 mkfs.ext4 /dev/sda2 格式化硬盘空间时,可能出现这种错误. had this situation at office where I was told to re-partiti ...
- WARNING: Re-reading the partition table failed with error 22: Invalid argument
在划分磁盘分区时,遇到错误"WARNING: Re-reading the partition table failed with error 22: Invalid argument&qu ...
- 解决linux分区提示doesn't contain a valid partition table
目前 partition table 大概有叁种: 最传统的 mbr.大容量的 gpt.小设备的 无; 遇上最后那种就会出现 "doesn't contain a valid partiti ...
- doesn't contain a valid partition table 解决方法
输入 fdisk -l 可以看到 输入 fdisk /dev/xvdb 跟着向导一步步做下去(如果不知道该输入什么,就输入“m”并回车,可以打印出菜单): Command (m for help): ...
- Mycat+Mysql 插入数据报错 i[Err] 1064 - partition table, insert must provide ColumnList
使用Navicat连接Mycat 8066 成功插入了分库表和全局表 1.全局表 sql如下: '); '); '); 插入成功! 2.分库表 sql如下: ', null, null, null, ...
- oracle partition table 分区表详解
Oracle partition table 分区表详解 分区表就是通过使用分区技术,将一张大表,拆分成多个表分区(独立的segment),从而提升数据访问的性能,以及日常的可维护性.分区表中,每个分 ...
- 计算机启动出现 Invalid Partition Table
计算机启动出现 Invalid Partition Table 解决办法 使用大白菜启动盘进入临时系统,打开程序DiskGenius 如果系统盘(一般为 C 盘)非活动状态,先激活 如果装系统的硬盘不 ...
- 如何移除EFI system partition?
莫名其妙, 在我的服务器上出现了这样一种分区, 上面写着EFI system, 删也删不掉, 因为删除分区的菜单是灰掉的. 找到了这篇文章, 成功的删掉了这个烦人的分区. 整个过程记录如下: 参考 ...
- 小米2s线刷出现remote: partition table doesn't exist
=================问题============ 小米2s线刷出现remote: partition table doesn't exist =================解决方案= ...
随机推荐
- sharepoint online
http://office.microsoft.com/en-001/sharepoint/sharepoint-online-online-collaboration-software-FX1037 ...
- Pair Project: Elevator Scheduler [电梯调度算法的实现和测试][关于电梯调度算法的附加思考]:刘耀先-11061183,罗凡-11061174
本文为对于电梯调度算法的三个附加题思考 1.改进电梯调度的interface 设计, 让它更好地反映现实, 更能让学生练习算法, 更好地实现信息隐藏和信息共享. <1>进一步提高API定义 ...
- python @property 属性
在绑定属性时,如果我们直接把属性暴露出去,显然不合适,是通过getter和setter方法来实现的,还可以定义只读属性,只定义getter方法,不定义setter方法就是一个只读属性: class P ...
- 实战中总结出来的CSS常见问题及解决办法
一.ul标签在Mozilla中默认是有padding值的,而在IE中只有margin有值. 二.同一个的class选择符可以在一个文档中重复出现,而id选择符却只能出现一次.对 一个标签同时使用cla ...
- xrange和range区别
range和xrange这两个函数基本都是在循环的时候使用的. >>> for x in range(10,21,1): ... print x ... 10 11 12 13 14 ...
- Ubuntu14.04建立WiFi热点
整理自Ubuntu 下建立WiFi热点的方法 Ubuntu14.04 Deepin2014分享WiFi 亲测成功 方法一:network manager 用Ubuntu自带的network manag ...
- POJ 1404 I-Keyboard (DP)
http://poj.org/problem?id=1404 题意 :手机上的要发短信的话,“我”字需要先按一下9键,再按3下6键,所以,现在想要重新布局每个键上的字母数,让最后的那个值最小,也就是说 ...
- Excel Cannot Connect to SharePoint List
As I am working in SharePoint support, I come across so many issues on day 2 day basis and always tr ...
- Android Touch事件传递机制
1.基础知识 (1) 所有Touch事件都被封装成了MotionEvent对象,包括Touch的位置.时间.历史记录以及第几个手指(多指触摸)等. (2) 事件类型分为ACTION_DOWN, ACT ...
- Android 设置控件可见与不可见
通常控件的可见与不可见分为三种情况 第一种 gone 表示不可见并且不占用空间 第二种 visible 表示可见 第三种 invisible 表示不 ...