- 浏览: 232338 次
文章分类
- 全部博客 (97)
- java (15)
- 设计模式 (11)
- spring (4)
- Hibernate (6)
- 笔试 (1)
- SSH整合 (1)
- VMware (1)
- linux (1)
- struts2 (1)
- easyui (2)
- html (1)
- CKEditor (1)
- CKfinder (1)
- beanutils (2)
- 装机 (1)
- spket (1)
- myeclipse (10)
- svn (2)
- 中文乱码 (7)
- oracle (13)
- windows (3)
- ext (9)
- javascript (1)
- PL/SQL (1)
- SecureCRT (1)
- tomcat (2)
- struts1 (5)
- 杂谈 (1)
- 工具使用 (1)
- 激活 (0)
- 事务 (1)
- UltraEdit (1)
- 数据库 (8)
- DbVisualizer (1)
- dwr (3)
最新评论
-
Veer-273:
谢谢 非常有用!
ext的GridPanel处理复合主键时只显示一条记录 -
hello_world_wdq:
谢谢,有用
ext的GridPanel处理复合主键时只显示一条记录 -
etunjour:
学长,谢谢你的分享哦。
银联商务笔试 -
meiyoudao:
...
secureCRT连接ubuntu问题- The remote system refused the connection -
waainli:
zhongying125 写道[b][/b][i][/i][u ...
设计模式之Builder
方法一:
create table TBL_MERCHANT_ACCOUNT_DETAIL2 partition by (WORKDATE) ( partition P1 values('20121023'), partition P2 values('20121024'), partition P3 values('20121025'), partition P4 values(default) ) as select * from PDS.TBL_MERCHANT_ACCOUNT_DETAIL; rename TBL_MERCHANT_ACCOUNT_DETAIL to TBL_MER_ACCOUNT_DETAIL_OLD; rename TBL_MERCHANT_ACCOUNT_DETAIL2 to TBL_MERCHANT_ACCOUNT_DETAIL;
优点:方法简单易用,由于采用DDL语句,不会产生UNDO,且只产生少量REDO,效率相对较高,而且建表完成后数据已经在分布到各个分区中了。 不足:对于数据的一致性方面还需要额外的考虑。由于几乎没有办法通过手工锁定T表的方式保证一致性,在执行CREATE TABLE语句和RENAME T_NEW TO T语句直接的修改可能会丢失,如果要保证一致性,需要在执行完语句后对数据进行检查,而这个代价是比较大的。另外在执行两个RENAME语句之间执行的对T的访问会失败。 适用于修改不频繁的表,在闲时进行操作,表的数据量不宜太大。
分区表的使用中,where条件如果有个分区字段,会自动检索该分区字段所在分区的记录,
因此,以下两句的执行效率是一致的:
select * from PDS.TBL_MERCHANT_ACCOUNT_DETAIL d where d.WORKDATE='20121024' and d.STEP_NAME='balanceMerchantAccount'; select * from PDS.TBL_MERCHANT_ACCOUNT_DETAIL partition(P2) d where d.STEP_NAME='balanceMerchantAccount';
方法二:
在线重定义
写道
1 创建测试表
用sys用户创建测试表
SQL> CREATE TABLE HR.ST (ID NUMBER, TIME DATE);
Table created.
SQL> INSERT INTO HR.ST SELECT ROWNUM, CREATED FROM DBA_OBJECTS;
50416 rows created.
SQL> commit;
Commit complete.
2 授权
SQL> grant execute on DBMS_REDEFINITION to hr;
Grant succeeded.
SQL> grant CREATE ANY TABLE, ALTER ANY TABLE, DROP ANY TABLE, LOCK ANY TABLE, SELECT ANY TABLE to hr;
Grant succeeded.
3 新建中间表(分区的表结构)
SQL> create table mid_st(id number primary key, time date) partition by range(time)
2 (
3 partition p1 values less than(to_date('2004-7-1', 'yyyy-mm-dd')),
4 partition p2 values less than(to_date('2005-1-1', 'yyyy-mm-dd')),
5 partition p3 values less than(to_date('2005-7-1', 'yyyy-mm-dd')),
6 partition p4 values less than(maxvalue)
7 );
Table created
4 验证
SQL> EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE(user, 'ST', DBMS_REDEFINITION.CONS_USE_PK);
PL/SQL procedure successfully completed
5 在线重定义
SQL> EXEC DBMS_REDEFINITION.START_REDEF_TABLE(USER, 'ST', 'MID_ST');
PL/SQL procedure successfully completed
6 同步数据(可选)
如果在执行DBMS_REDEFINITION.START_REDEF_TABLE()过程和执行DBMS_REDEFINITION.FINISH_REDEF_TABLE()过程直接在重定义表上执行了大量的DML操作,那么可以选择执行一次或多次的SYNC_INTERIM_TABLE()过程,以减少最后一步执行FINISH_REDEF_TABLE()过程时的锁定时间。
SQL> EXEC DBMS_REDEFINITION.SYNC_INTERIM_TABLE(USER, 'ST', 'MID_ST');
PL/SQL procedure successfully completed
7 结束重定义
SQL> EXEC DBMS_REDEFINITION.FINISH_REDEF_TABLE(USER, 'ST', 'MID_ST');
PL/SQL procedure successfully completed
8 查看分区结果
SQL> select a.table_name, a.partition_name from user_tab_partitions a;
TABLE_NAME PARTITION_NAME
------------------------------ ------------------------------
ST P1
ST P2
ST P3
ST P4
9 放弃在线重定义
可以在执行dbms_redefinition.start_redef_table之后到执行dbms_redefinition.finish_redef_table之前的时间里执行:
DBMS_REDEFINITION.abort_redef_table(user, 'st', 'mid_st')以放弃执行在线重定义。
10 常见问题
10.1 无主键
SQL> EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE(user, 'ST', DBMS_REDEFINITION.CONS_USE_PK);
BEGIN DBMS_REDEFINITION.CAN_REDEF_TABLE(user, 'ST', DBMS_REDEFINITION.CONS_USE_PK); END;
*
ERROR at line 1:
ORA-12089: cannot online redefine table "HR"."ST" with no primary key
ORA-06512: at "SYS.DBMS_REDEFINITION", line 137
ORA-06512: at "SYS.DBMS_REDEFINITION", line 1478
ORA-06512: at line 1
出错了, 该表上缺少主键, 为该表建主键. 再执行验证.
SQL> alter table st add constraint pk_t primary key(id);
Table altered.
用这句删除materialized view 即可继续进行
drop materialized view log on <tablename>;
drop materialized view log on t; OR drop materialized t;
10.2 未授权
SQL> EXEC DBMS_REDEFINITION.START_REDEF_TABLE(USER, 'ST', 'MID_ST');
begin DBMS_REDEFINITION.START_REDEF_TABLE(USER, 'ST', 'MID_ST'); end;
ORA-01031: insufficient privileges
ORA-06512: at "SYS.DBMS_REDEFINITION", line 50
ORA-06512: at "SYS.DBMS_REDEFINITION", line 1343
ORA-06512: at line 2
用sys用户创建测试表
SQL> CREATE TABLE HR.ST (ID NUMBER, TIME DATE);
Table created.
SQL> INSERT INTO HR.ST SELECT ROWNUM, CREATED FROM DBA_OBJECTS;
50416 rows created.
SQL> commit;
Commit complete.
2 授权
SQL> grant execute on DBMS_REDEFINITION to hr;
Grant succeeded.
SQL> grant CREATE ANY TABLE, ALTER ANY TABLE, DROP ANY TABLE, LOCK ANY TABLE, SELECT ANY TABLE to hr;
Grant succeeded.
3 新建中间表(分区的表结构)
SQL> create table mid_st(id number primary key, time date) partition by range(time)
2 (
3 partition p1 values less than(to_date('2004-7-1', 'yyyy-mm-dd')),
4 partition p2 values less than(to_date('2005-1-1', 'yyyy-mm-dd')),
5 partition p3 values less than(to_date('2005-7-1', 'yyyy-mm-dd')),
6 partition p4 values less than(maxvalue)
7 );
Table created
4 验证
SQL> EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE(user, 'ST', DBMS_REDEFINITION.CONS_USE_PK);
PL/SQL procedure successfully completed
5 在线重定义
SQL> EXEC DBMS_REDEFINITION.START_REDEF_TABLE(USER, 'ST', 'MID_ST');
PL/SQL procedure successfully completed
6 同步数据(可选)
如果在执行DBMS_REDEFINITION.START_REDEF_TABLE()过程和执行DBMS_REDEFINITION.FINISH_REDEF_TABLE()过程直接在重定义表上执行了大量的DML操作,那么可以选择执行一次或多次的SYNC_INTERIM_TABLE()过程,以减少最后一步执行FINISH_REDEF_TABLE()过程时的锁定时间。
SQL> EXEC DBMS_REDEFINITION.SYNC_INTERIM_TABLE(USER, 'ST', 'MID_ST');
PL/SQL procedure successfully completed
7 结束重定义
SQL> EXEC DBMS_REDEFINITION.FINISH_REDEF_TABLE(USER, 'ST', 'MID_ST');
PL/SQL procedure successfully completed
8 查看分区结果
SQL> select a.table_name, a.partition_name from user_tab_partitions a;
TABLE_NAME PARTITION_NAME
------------------------------ ------------------------------
ST P1
ST P2
ST P3
ST P4
9 放弃在线重定义
可以在执行dbms_redefinition.start_redef_table之后到执行dbms_redefinition.finish_redef_table之前的时间里执行:
DBMS_REDEFINITION.abort_redef_table(user, 'st', 'mid_st')以放弃执行在线重定义。
10 常见问题
10.1 无主键
SQL> EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE(user, 'ST', DBMS_REDEFINITION.CONS_USE_PK);
BEGIN DBMS_REDEFINITION.CAN_REDEF_TABLE(user, 'ST', DBMS_REDEFINITION.CONS_USE_PK); END;
*
ERROR at line 1:
ORA-12089: cannot online redefine table "HR"."ST" with no primary key
ORA-06512: at "SYS.DBMS_REDEFINITION", line 137
ORA-06512: at "SYS.DBMS_REDEFINITION", line 1478
ORA-06512: at line 1
出错了, 该表上缺少主键, 为该表建主键. 再执行验证.
SQL> alter table st add constraint pk_t primary key(id);
Table altered.
用这句删除materialized view 即可继续进行
drop materialized view log on <tablename>;
drop materialized view log on t; OR drop materialized t;
10.2 未授权
SQL> EXEC DBMS_REDEFINITION.START_REDEF_TABLE(USER, 'ST', 'MID_ST');
begin DBMS_REDEFINITION.START_REDEF_TABLE(USER, 'ST', 'MID_ST'); end;
ORA-01031: insufficient privileges
ORA-06512: at "SYS.DBMS_REDEFINITION", line 50
ORA-06512: at "SYS.DBMS_REDEFINITION", line 1343
ORA-06512: at line 2
优点:保证数据的一致性,在大部分时间内,表T都可以正常进行DML操作。只在切换的瞬间锁表,具有很高的可用性。这种方法具有很强的灵活性,对各种不同的需要都能满足。而且,可以在切换前进行相应的授权并建立各种约束,可以做到切换完成后不再需要任何额外的管理操作。 不足:实现上比上面两种略显复杂。 适用于各种情况。 然而,在线表格重定义也不是完美无缺的。下面列出了Oracle9i重定义过程的部分限制。 你必须有足以维护两份表格拷贝的空间。 你不能更改主键栏。 表格必须有主键。 必须在同一个大纲中进行表格重定义。 在重定义操作完成之前,你不能对新加栏加以NOT NULL约束。 表格不能包含LONG、BFILE以及用户类型(UDT)。 不能重定义链表(clustered tables)。 不能在SYS和SYSTEM大纲中重定义表格。 不能用具体化视图日志(materialized view logs)来重定义表格;不能重定义含有具体化视图的表格。 不能在重定义过程中进行横向分集(horizontal subsetting)。
方法三:
交换分区
步骤: SQL> CREATE TABLE T (ID NUMBER PRIMARY KEY, TIME DATE); 表已创建。 SQL> INSERT INTO T SELECT ROWNUM, CREATED FROM DBA_OBJECTS; 已创建6264行。 SQL> COMMIT; 提交完成。 SQL> CREATE TABLE T_NEW (ID NUMBER PRIMARY KEY, TIME DATE) PARTITION BY RANGE (TIME) 2 (PARTITION P1 VALUES LESS THAN (TO_DATE(’2005-7-1’, ’YYYY-MM-DD’)), 3 PARTITION P2 VALUES LESS THAN (MAXVALUE)); 表已创建。 SQL> ALTER TABLE T_NEW EXCHANGE PARTITION P1 WITH TABLE T; 表已更改。 SQL> RENAME T TO T_OLD; 表已重命名。 SQL> RENAME T_NEW TO T; 表已重命名。 SQL> SELECT COUNT(*) FROM T; COUNT(*) ---------- 6264
优点:只是对数据字典中分区和表的定义进行了修改,没有数据的修改或复制,效率最高。如果对数据在分区中的分布没有进一步要求的话,实现比较简单。在执行完RENAME操作后,可以检查T_OLD中是否存在数据,如果存在的话,直接将这些数据插入到T中,可以保证对T插入的操作不会丢失。 不足:仍然存在一致性问题,交换分区之后RENAME T_NEW TO T之前,查询、更新和删除会出现错误或访问不到数据。如果要求数据分布到多个分区中,则需要进行分区的SPLIT操作,会增加操作的复杂度,效率也会降低。 适用于包含大数据量的表转到分区表中的一个分区的操作。应尽量在闲时进行操作。
发表评论
-
oracle的job的interval设置
2012-11-16 16:29 1442job的步骤如下: 记述一个创建一个简单的j ... -
DbVisualizer 8.0.11 出现乱码问题
2012-11-15 10:36 1390DbVisualizer 8.0.11 出现乱码问题 在SQL ... -
oracle分区索引使用问题
2012-11-14 19:17 1194表用A列作分区,索引用B做局部分区索引(local pa ... -
oracle随机获取数据
2012-11-13 19:30 727oracle随机获取前4条数据: select ... -
PLS-00103-存储过程中运行alter table
2012-11-07 16:09 2325存储过程中运行alter table出现如下错误: ... -
Oracle中的Truncate和Delete语句
2012-11-07 09:17 978首先讲一下,truncate命 ... -
Oracle\MS SQL Server的数据库多表关联更新UPDATE与多表更新
2012-11-06 12:35 1114一条Update更新语句是不能更新多张表的,除非使用触发 ... -
在Oracle中取得查询结果的前10条或第10条到第20条录
2012-10-29 18:30 1314ROWNUM常见的用途就是用来分页输出.比如 SELEC ... -
Oracle数据库:Thread 1 cannot allocate new log, sequence 22 Checkpoint not complete
2012-07-26 19:38 6936遇到问题: Thread 1 cannot alloc ... -
oracle数据库:SMON: Parallel transaction recovery tried 引发的问题
2012-07-25 19:14 1568SMON: Parallel transaction r ... -
oracle数据库Process OS id : 799228 alive after kill
2012-07-25 19:10 1239原因: 操作系统需要时间来kill进程 On som ... -
oracle数据库Immediate Kill Session错误解决方案
2012-07-25 18:30 21791.错误信息 Immediate Kill Se ... -
EXP-00024,Oracle未安装导出视图解决方案
2012-07-25 16:51 3925EXP-00024: 未安装导出视图, 请通知您的 DB ...
相关推荐
DBMS_REDEFINITION方法是Oracle提供的一个工具包,用于在不锁定原表的情况下,将非分区表在线转换为分区表。通过DBMS_REDEFINITION包中的步骤和函数,可以实现分区表的在线重定义,这种方式对系统影响最小,但需要...
1. 现有表转换:已有的非分区表不能直接转为分区表,需要使用Oracle提供的在线重定义功能。 三、Oracle分区方法 1. 范围分区:基于特定列的数值范围进行分区,如按序号或日期创建分区。 2. Hash分区:通过哈希函数...
- 非分区表转换困难:已有的大表难以直接转为分区表,但Oracle提供在线重定义表的功能。 5. **表分区的类型及操作** - **范围分区**:数据按特定范围分配到各个分区,如日期、数字范围。例如,销售数据按月份...
- **不支持的功能**:此函数目前不支持Oracle中的分区、函数索引、位图索引等特殊索引定义、自定义数据类型、ROWID、RAW等特殊数据类型、外键以及自定义约束。 - **数据类型转换**:Oracle中的`DATE`和`TIMESTAMP`...
9. **优化与调整**:转换后的Oracle表可能需要根据Oracle的最佳实践进行一些调整,如分区策略、索引优化等。 总的来说,这个过程涉及到数据库设计、SQL语法理解和自动化脚本编写。对于大型或复杂的数据库迁移,可能...
- 非分区表无法直接转为分区表,需借助Oracle的在线重定义功能。 - 管理复杂性增加,特别是对于多级分区和复杂查询。 4. **表分区的几种类型及操作方法** - **范围分区**: - 范围分区根据指定的键值范围将数据...
【MySQL进阶学习】优化索引与分区表 在MySQL数据库管理中,索引和分区是两个关键的优化策略,用于提升查询性能和管理大规模数据。这篇文章将深入探讨这两个主题,帮助你理解如何有效地利用它们。 优化索引是提高...
Oracle分区是数据库优化的一种手段,它将大表分成较小、更易管理的部分,提高查询性能。主要有以下几种分区方式: 1. **范围分区**:基于列值的范围进行划分。 2. **列表分区**:基于列值属于预定义的一组列表进行...
物化视图可以像普通表一样被查询,并且可以基于分区表,自身也可进行分区,进一步提升查询效率。 物化视图根据其功能可分为三类:包含聚集的物化视图,只包含连接的物化视图,以及嵌套物化视图。这三类物化视图在...
分区表是SQL2005的一大亮点,尤其适用于大数据量的处理,但创建非分区索引可能会使表自动转为非分区表,需谨慎操作。 在开发方面,SQL2005支持CLR集成,使得.NET开发者可以直接使用C#或VB.NET编写存储过程和函数,...
此外,还有开源工具如 ora2pg、Data Export等,虽然它们主要针对Oracle到PostgreSQL的迁移,但某些情况下也可以进行定制以适应MySQL到SQL Server的迁移。 3. **SSMA for MySQL**:该工具可以自动分析、转换MySQL的...
NoSQL(Not Only SQL)数据库与传统的关系数据库(如MySQL、Oracle等)相比,有其独特的应用场景和技术特点。 - **数据模型差异**:关系数据库采用固定模式的数据模型,数据存储在一个或多个表格中,并通过主键和...
- 提取姓名的大写首字母缩写:将姓名各单词首字母提取并转为大写。 - 按字符串中的数值排序:对数字字符串进行排序。 - 根据表中的行创建一个分隔列表:将行数据合并为一个逗号分隔的字符串。 - 提取第n个分隔的...
逻辑结构设计则转化为数据库语言,如ER模型转为SQL表结构,包括字段名、数据类型、主键、外键等。物理结构设计考虑实际的存储和性能优化,包括索引策略、分区、存储格式等。 运用设计部分详细说明了数据的生命周期...
Dategrivde可能是一个拼写错误,我们通常指的是知名的数据库管理系统如Oracle的Datagrid或Java的JTable组件。这个过程涉及到数据的转换、验证和加载,通常用于数据分析、报表生成或数据存储。 描述中提到的“带有...
- 逻辑设计:将概念设计转化为特定数据库系统的表结构,如ER图转为关系模式。 - 物理设计:考虑存储效率和性能,优化数据的物理存储结构和访问方法。 3. SQL语言: - SELECT:用于查询数据,可以指定查询字段、...
- **格式化分区**:`FORMAT A:/Q/U/S` 可用于格式化磁盘分区,并将其设置为系统分区。 ### 12. Cache与Buffer的区别 - **Buffer**:用于暂时存储数据,以便快速访问或处理。缓冲区通常用于输入/输出设备间的数据...