Oracle数据迁移笔记-Rownum与序列的自增长的组合用法技巧
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与序列的自增长的组合用法技巧的更多相关文章
- MS SQL到Oracle的数据迁移笔记
MS SQL到Oracle的数据迁移笔记 一.任务背景 旧系统使用MS SQL Server数据库,新系统使用Oracle数据库,现在需要将旧系统中的数据迁移到新系统中,旧数据按照约定的规则转换后,能 ...
- Oracle数据迁移至HBase操作记录
Oracle数据迁移至HBase操作记录 @(HBase) 近期需要把Oracle数据库中的十几张表T级别的数据迁移至HBase中,过程中遇到了许多苦难和疑惑,在此记录一下希望能帮到一些有同样需求的兄 ...
- Oracle数据迁移expdp/impdp
Oracle数据迁移expdp/impdp目的:指导项目侧自行进行简单的数据泵迁移工作. 本文实验环境:Oracle 11.2.0.4,利用数据库自带的scott示例用户进行试验测试. 1.首先需要创 ...
- Oracle数据迁移-系统数据合并笔记
创建临时表:execute immediate 'sql'; 通过临时表和关联查询解决循环处理效率低下,大数据操作移植时时间太长的问题. 结构相同的系统数据库表移植,案例如下: create or r ...
- Oracle数据迁移至MySQL
ORACLE DB: 11.2.0.3.0 MYSQL DB: 5.5.14 因项目需求,需要将ORACLE生产中数据迁移至MYSQL数据库中作为初始数据,方法有如下几种: 1.ORACLE OGG ...
- 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 ...
- Oracle数据迁移后由列的直方图统计信息引起的执行计划异常
(一)问题背景 在使用impdp进行数据导入的时候,往往在导入表和索引的统计信息的时候,速度非常慢,因此我在使用impdp进行导入时,会使用exclude=table_statistics排除表的统计 ...
- 【Oracle 数据迁移】环境oracle 11gR2,exp无法导出空表的表结构【转载】
今天做数据迁移,但是发现有些空表无法exp,后来找到问题所在. [原文]:http://www.cnblogs.com/wenlong/p/3684230.html 11GR2中有个新特性,当表无数据 ...
- oracle数据迁移
通过这个文章演示一下Oracle的表空间迁移流程以及需要注意的诸多事项. 实验目标:将ora10g数据库实例上的表空间TBS_SEC_D迁移到secooler数据库实例上操作系统:Redhat 5.3 ...
随机推荐
- ORACLE的监听日志太大,客户端无法连接
数据库sqlplus能连接,plsql连接失败,也不报错,就定位到了是不是监听出了什么问题,删除监听,重建监听,重启监听,各种尝试都没解决问题. 却是监听日志太大导致的问题,一下是处理步骤: 查看监听 ...
- 简单VR照片 使用陀螺仪、姿态角(Roll、Pitch、Yaw )、四元数
最近在做一个类似VR照片的demo,跟全景图片也很像,只是VR照片与全景720度显示,我只做了180度.但我发现他们实现的原理有一丝相似,希望可以给一些想入行AR.VR的朋友一些提示吧. ...
- Java IO流之转换流
一.转换流 1.在IO包中,实际上就是分为字节流和字符流,但是除了这两个流之外,还存在了一组字节流-字符流的转换流 2.转换流用于在字节流和字符流之间转换 3.转换流本身是字符流 二.两种转换流 Ou ...
- Spring Task每次都会调用两次的问题
最近一个Spring Mvc的项目中需要定时执行一个任务,所以使用了spring 自带的Task功能.本地调试的时候一切都正常,可是部署到服务器上后,每次任务都会被调用两次.在网上搜索了相关的问题,排 ...
- 【2017-06-06】Ajax完整结构、三级联动的制作
一.Ajax完整结构 $.ajax({ url:"Main.ashx", data:{}, dataType:"json", type:"post&q ...
- Publishing failed with multiple errors.问题解决
问题:Publishing failed with multiple errors.(发布失败与多个错误) 原因:项目工程文件删除,但eclipse里面仍显示存在. 解决方案:刷新项目工程,重新部署, ...
- Spring+SpringMVC+MyBatis深入学习及搭建(九)——MyBatis和Spring整合
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6964162.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(八)--My ...
- java基础(一章)
java基础(一章) 1. java是一种面向对象的高级编程语言. 2. java包括: javase(java基础) ...
- java基础(四章)
一. switch结构(开关语句)的语法 switch(表达式 ){ ------- [dream1]类型为int.char case 常量1 : ---------[ ...
- Android网络请求框架AsyncHttpClient实例详解(配合JSON解析调用接口)
最近做项目要求使用到网络,想来想去选择了AsyncHttpClient框架开进行APP开发.在这里把我工作期间遇到的问题以及对AsyncHttpClient的使用经验做出相应总结,希望能对您的学习有所 ...