iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >ORACLE 在线表重定义
  • 566
分享到

ORACLE 在线表重定义

2024-04-02 19:04:59 566人浏览 独家记忆
摘要

oracle 在实际中一些表由于业务量增大,一些原先规划不是很大的表的数据量大增,为了优化要把这些表从普通表变成分区表。现在就介绍ORACLE自带的一种技术来处理这种情况-这种技术叫在线表重定义。第一步建立

oracle 在实际中一些表由于业务量增大,一些原先规划不是很大的表的数据量大增,为了优化要把这些表从普通表变成分区表。现在就介绍ORACLE自带的一种技术来处理这种情况-这种技术叫在线表重定义。

第一步建立临时表:

create table test_table

( ID NUMEBER(10) NOT NULL,

 STATUS VARCHAR2(30) NULL,

CREATE_DATE  DATE

)PARTITioN BY RANGE(CREATE_DATE)
( PARTITION part23 VALUES LESS THAN (TO_DATE('2010-09-24','YYYY-MM-DD')),
 PARTITION part24 VALUES LESS THAN(TO_DATE('2010-09-25', 'YYYY-MM-DD')),
 PARTITION Part25 VALUES LESS THAN(TO_DATE('2010-09-26', 'YYYY-MM-DD')),
 PARTITION partmax VALUES LESS THAN(MAXVALUE)
);

alter table test_table add constraint test_table_pk primary key(id);

第二步 判断目标数据表是否可以进行重定义 。利用的DBMS_REDEFINITION包的CAN_REDEF_TABLE的方法进行判断。

exec dbms_redefinition.can_redef_table('user','table',dbms_redefinition.cons_use_pk);

使用cons_use_pk重定义的时候创建的物化视图是基于普通的刷新模式.

也可以用ROWID的方法

exec dbms_redefinition.can_redef_table('user','table',dbms_redefinition.cons_use_rowid);

使用cons_use_rowid重定义的时候创建的物化视图是基于ROWID刷新的.

第三步 开始重定义

exec dbms_redefinition.start_redef_table('user', 'table', 'test_table');

同步临时表与原始表中的数据

exec dbms_redefinition.sync_interim_table('user', 'table', 'test_table');

开始复制表的属性

declareCLAR

num_errors PLS_INTEGER; 

BEGIN 

  DBMS_REDEFINITION.COPY_TABLE_DEPENDENTS('user','table','test_table',

   DBMS_REDEFINITION.CONS_ORIG_PARAMS, TRUE, TRUE, TRUE, TRUE, num_errors); 

END; 

包括索引,规则,促发器

完成重定义

exec dbms_redefinition.finish_redef_table('user', 'table', 'test_table');



_pk);




您可能感兴趣的文档:

--结束END--

本文标题: ORACLE 在线表重定义

本文链接: https://www.lsjlt.com/news/41838.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • oracle在线重定义表有什么功能
    这篇文章主要讲解了“oracle在线重定义表有什么功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“oracle在线重定义表有什么功能”吧!在线重定义表具有...
    99+
    2024-04-02
  • Oracle在线重定义之DBMS_REDEFINITION
    11g官方文档关于DBMS_REDEFINITION的详细说明: ***************************************************************...
    99+
    2024-04-02
  • 普通表转分区表(在线重定义)
    确认表是否可以分区 SQL> BEGIN   2  DBMS_REDEFINITION.CAN_REDEF_TABLE('SCOTT','EM...
    99+
    2024-04-02
  • 在线重定义步骤
    表在线重定义原理:         oracle表的在线重定义是通过,prebuilt物化视图实现的,在执行DBMS_REDEFINITION.START_REDEF_TABLE()后,我们可以通过查询,...
    99+
    2024-04-02
  • oracle如何实现在线重定义与普通表改为分区表
    小编给大家分享一下oracle如何实现在线重定义与普通表改为分区表,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、什么是在线重定义要了解什么是在线重定义技术,我想从表分区开始说起。在生产...
    99+
    2024-04-02
  • Oracle 12.2中如何联机重定义使用VPD策略的表
    这篇文章主要为大家展示了“Oracle 12.2中如何联机重定义使用VPD策略的表”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Oracle 12.2中如何联机...
    99+
    2024-04-02
  • oracle表分区的定义是什么
    Oracle表分区是将表数据按一定的规则分割存储在不同的分区中,以提高查询性能和管理数据的效率。通过表分区,可以将表数据存储在不同的...
    99+
    2024-04-09
    oracle
  • 【自定义表单】自定义表单设计
    1.后端设计1 diy_field_pool 字段池(我们定义好的字段类型)diy_form 表单表(记录用户自定义的表单)diy_form_field 表单字段表(记录某张表单中有哪些字段)diy...
    99+
    2023-08-21
    数据库 sql mysql
  • Oracle 12.2如何使用联机重定义对表进行多处改变
    小编给大家分享一下Oracle 12.2如何使用联机重定义对表进行多处改变,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!下面的例子将演示如何使用联机重定义操作来对表进行多处改变,原始表jy...
    99+
    2024-04-02
  • Oracle 12.2如何使用dbms_redefinition.redef_table过程来重定义表的存储属性
    这篇文章主要为大家展示了“Oracle 12.2如何使用dbms_redefinition.redef_table过程来重定义表的存储属性”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领...
    99+
    2024-04-02
  • 怎么在Java中自定义线程池
    这篇文章给大家介绍怎么在Java中自定义线程池,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。【1】接口定义public interface IThreadPool<Job exten...
    99+
    2023-06-06
  • Oracle中怎么利用联机重定义给表增加新列与分区
    本篇文章给大家分享的是有关Oracle中怎么利用联机重定义给表增加新列与分区,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1.用要执行联机重定...
    99+
    2024-04-02
  • oracle中exception定义
    在Oracle中,异常是指在程序执行过程中发生的意外或错误事件。当异常发生时,程序会中断当前的执行流程,并跳转到异常处理器中进行处理...
    99+
    2023-08-08
    oracle
  • 怎么在java项目中自定义线程池
    怎么在java项目中自定义线程池?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。使用线程池时,可以使用 newCachedThreadPool()或者 newFi...
    99+
    2023-05-31
    java 线程池 ava
  • 如何在html中自定义有序列表
    如何在html中自定义有序列表?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。list-style-type 属性设置列表项标记的类型。语法:元素{list-style-ty...
    99+
    2023-06-15
  • Android自定义View实现体重表盘详解流程
    目录效果视频分析起始角度圆弧指针代码初始化属性画布绘制内圆弧绘制外圆弧绘制中间指针绘制中间文字绘制左右两边文字动画全部代码下载链接效果视频 分析 起始角度 如下图所示,起点角度为1...
    99+
    2024-04-02
  • Oracle12.2怎么用对象数据类型来重定义表
    本篇内容介绍了“Oracle12.2怎么用对象数据类型来重定义表”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2024-04-02
  • 如何在 Go 和 Laravel 中实现自定义重定向逻辑?
    随着互联网的发展,网站的重定向功能越来越重要。在很多情况下,我们需要在网站上进行重定向操作,例如我们要将用户从一个页面重定向到另一个页面,或者将用户从一个域名重定向到另一个域名。在本文中,我们将讨论如何在 Go 和 Laravel 中实现自...
    99+
    2023-08-03
    laravel 打包 重定向
  • CSS虚线下划线及虚线怎么定义
    今天小编给大家分享一下CSS虚线下划线及虚线怎么定义的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解...
    99+
    2024-04-02
  • python多线程之自定义线程类
    '''自定义线程类''' from threading import Thread import time #创建一个类,并继承Python的Thread类,且重写run()方法实现具体的执行顺序由自己来定义 class MyThread...
    99+
    2023-01-31
    自定义 线程 多线程
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作