Rownum序列的自增长的组合用法技巧

根据序列自增长的步长规律,结合表行记录Rownum值的规则批量生成表的行记录主键的用法技巧

案例如下:

CREATE OR REPLACE PROCEDURE BILL_TRANSFER
   AUTHID CURRENT_USER
IS
   create_sql   );
   update_sql   );
   insert_sql   );
   V_info_id    NUMBER;
   info_count   NUMBER;
BEGIN

   --1、充分利用序列的自增长和Rownum的用法生成新数据的主键ID(原系统数据主键与新数据主键对应关系)
   --获取主键序列最大值
   SELECT seq_bill_info.nextval INTO V_info_id FROM dual;

   --创建新主键与原主键的映射关系表
   create_sql :=
         'create table bill_info_map as select bill_id,ROWNUM +'
      || V_info_id
      || ' as  bill_id_new from bill_info@jn order by bill_id';

   EXECUTE IMMEDIATE create_sql;

   --2、新数据主键序列值占用更新(根据Oracle序列自增长步长规则更新其占用)
   --本次迁移的数据总量
   SELECT COUNT (bi.bill_id)
     INTO info_count
     FROM bill_info@jn bi;

   --更新序列值
   update_sql := 'alter sequence seq_bill_info increment BY ' || info_count;

   EXECUTE IMMEDIATE update_sql;

   SELECT seq_bill_info.NEXTVAL INTO V_info_id FROM DUAL;

   update_sql := 'alter sequence seq_bill_info increment BY 1';

   EXECUTE IMMEDIATE update_sql;

   --3、创建截止迁移之时起票据基本信息的备份表
   create_sql :=
         'create table bill_info_copy as select m.bill_id_new bill_id,bi.bill_code,bi.bill_status,bi.bill_type,bi.is_valid,bi.receive_name,oi.org_id_new org_id,'
      || '''数据迁移'''
      || ' AS str_remark'
      || ' from bill_info@jn bi'
      || ' join bill_info_map m on m.bill_id=bi.bill_id'
      || ' left join (select org_id, org_id org_id_new from org_info@jn where org_type ='
      '''
      || ' and org_id <> 60 UNION select 60 org_id, org_id org_id_new from org_info where org_id = 61) oi'
      || ' on bi.org_id = oi.org_id';

   EXECUTE IMMEDIATE create_sql;

   --4、导入交款汇总数据
   insert_sql := 'insert into bill_info  select * from bill_info_copy';

   EXECUTE IMMEDIATE insert_sql;

   COMMIT;

END BILL_TRANSFER;

以上案例分析,

第一步:取出目前序列的最大值或者当前使用的值;
第二步:根据Rownum从1开始,自增长的规律,结合当前序列的最大值批量生成新的主键ID;

第三步:主键已经占用的值需要同步将序列的值同步更新,根据序列的步长修改规则修改其步长以免之后新生成的主键与现有的数据主键冲突。

Oracle数据迁移笔记-Rownum与序列的自增长的组合用法技巧的更多相关文章

  1. MS SQL到Oracle的数据迁移笔记

    MS SQL到Oracle的数据迁移笔记 一.任务背景 旧系统使用MS SQL Server数据库,新系统使用Oracle数据库,现在需要将旧系统中的数据迁移到新系统中,旧数据按照约定的规则转换后,能 ...

  2. Oracle数据迁移至HBase操作记录

    Oracle数据迁移至HBase操作记录 @(HBase) 近期需要把Oracle数据库中的十几张表T级别的数据迁移至HBase中,过程中遇到了许多苦难和疑惑,在此记录一下希望能帮到一些有同样需求的兄 ...

  3. Oracle数据迁移expdp/impdp

    Oracle数据迁移expdp/impdp目的:指导项目侧自行进行简单的数据泵迁移工作. 本文实验环境:Oracle 11.2.0.4,利用数据库自带的scott示例用户进行试验测试. 1.首先需要创 ...

  4. Oracle数据迁移-系统数据合并笔记

    创建临时表:execute immediate 'sql'; 通过临时表和关联查询解决循环处理效率低下,大数据操作移植时时间太长的问题. 结构相同的系统数据库表移植,案例如下: create or r ...

  5. Oracle数据迁移至MySQL

    ORACLE DB: 11.2.0.3.0 MYSQL DB: 5.5.14 因项目需求,需要将ORACLE生产中数据迁移至MYSQL数据库中作为初始数据,方法有如下几种: 1.ORACLE OGG ...

  6. oracle数据迁移之Exp和Expdp导出数据的性能对比与优化

    https://wangbinbin0326.github.io/2017/03/31/oracle%E6%95%B0%E6%8D%AE%E8%BF%81%E7%A7%BB%E4%B9%8BExp%E ...

  7. Oracle数据迁移后由列的直方图统计信息引起的执行计划异常

    (一)问题背景 在使用impdp进行数据导入的时候,往往在导入表和索引的统计信息的时候,速度非常慢,因此我在使用impdp进行导入时,会使用exclude=table_statistics排除表的统计 ...

  8. 【Oracle 数据迁移】环境oracle 11gR2,exp无法导出空表的表结构【转载】

    今天做数据迁移,但是发现有些空表无法exp,后来找到问题所在. [原文]:http://www.cnblogs.com/wenlong/p/3684230.html 11GR2中有个新特性,当表无数据 ...

  9. oracle数据迁移

    通过这个文章演示一下Oracle的表空间迁移流程以及需要注意的诸多事项. 实验目标:将ora10g数据库实例上的表空间TBS_SEC_D迁移到secooler数据库实例上操作系统:Redhat 5.3 ...

随机推荐

  1. jQuery选择器中的空格问题

    前几天就遇到过这样的问题,明明我用的是('tr :even').css('background','#ccc')想改变表格中行的背景色,反复试了还是没改变.还问了度娘还是没找到原因所在(当时问题描述的 ...

  2. offsetHeight/Width clientHeight/Width scrollHeight/Width等高宽算法

    图解: jquery里的对应取法: clientHeight/Width:innerHeight/Width(), offsetHeight/Width: outerHeight/Width(). w ...

  3. 【转载】C/C++中的char,wchar,TCHAR

    点击这里查看原文章 总体简介:由于字符编码的不同,在C++中有三种对于字符类型:char, wchar_t , TCHAR.其实TCHAR不能算作一种类型,他紧紧是一个宏.我们都知道,宏在预编译的时候 ...

  4. 3分钟带你了解PowerShell发展历程——PowerShell各版本资料整理

    本文带你了解PowerShell发展历程,顺便整理了一点资料,方便大家查询. Windows PowerShell® 是基于任务的命令行管理程序和脚本语言,专为进行系统管理而设计. 在 .NET Fr ...

  5. python-广度优先搜索

    广度优先搜索 下面我们来来BFS算法策略: 比如:我们要从双子峰---->金门大桥,最短路径如何? 我们利用广度优先搜索来一步步求解,注意广度优先搜索在于的关键在于"广",也 ...

  6. 【Selenium】idea的selenium环境配置

    1.maven配置 下载地址:http://maven.apache.org/download.cgi# 下载内容:apache-maven-3.5.0-bin.zip 环境变量:M2_HOME:E: ...

  7. STM8程序在IAR中报错 unable to allocate space for sections

    Error[Lp011]: section placement failed: unable to allocate space for sections/blocks with a total es ...

  8. C++构造函数(二)

    本篇是介绍C++的构造函数的第二篇(共二篇),属于读书笔记,对C++进行一个系统的复习. 复制构造函数 复制构造函数是构造函数的一种,也被称为拷贝构造函数,他只有一个参数,参数类型是本类的引用.默认构 ...

  9. TeamViewer——可以实现在手机上随时远程控制你的电脑

    小编今天给大家推荐一款强大的远程控制软件——TeamViewer,可以让你的手机连接你自己的电脑,不管你身处何处,只要电脑和手机都能联网,那么你就可以在手机上控制你的电脑了.以下介绍下如何安装和使用方 ...

  10. 上下文Context详细介绍

    1.先看看它的继承结构,下图可以看出Context首先是一个抽象类,继承了Object,Activity,Service,Application都继承了它 2.API中对它的描述: @1Context ...