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 ...
随机推荐
- JAVA网络编程TCP通信
Socket简介: Socket称为"套接字",描述IP地址和端口.在Internet上的主机一般运行多个服务软件,同时提供几种服务,每种服务都打开一个Socket,并绑定在一个端 ...
- Python多线程和多进程谁更快?
python多进程和多线程谁更快 python3.6 threading和multiprocessing 四核+三星250G-850-SSD 自从用多进程和多线程进行编程,一致没搞懂到底谁更快.网上很 ...
- QUICK-AP + BETTERCAP 替换局域网内其他用户的下载文件为自定义文件
环境需求 :kali系统 , .0版本 :quick-ap :bettercap :bettercap-proxy-modules :...... 主要环境搭建 目的:替换局域网用户的下载文件,变为我 ...
- D. 实验室传染病
D. 实验室传染病 题意 给出 n 个人的位置,以及每个人的传染范围,当一个人患病时,他的传染范围内(包括边界上)的人全部会被感染并继续向外传播. 求以每个人为传染源最多有多少人被感染. 分析 首先二 ...
- 每天一个JS 小demo之日历制作。主要知识点:日期函数
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- windows embedded compact 2013 正版免费下载
不知道wince2013是不是真的免费了,不过可以试一下! 下载地址:http://www.microsoft.com/en-us/download/details.aspx?id=39268 你仍然 ...
- python基础操作_字符串操作_列表操作list
#字符串可以通过下表取值,如下程序 names='java python' print(names[0],names[5]) #使用for循环轮询所有name值 ''' for name in nam ...
- git代码回滚
有时候我们用git提交代码后发生了错误,代码冲突了啊等等,我们需要将代码回到以前的某个版本 git代码回退有两种办法 一.git reset(推荐): 它是将最新的commit删除,用以前的某个版本的 ...
- Ubuntu下录音机程序的使用
在Ubuntu中使用系统自带的录音机程序可以录制电脑的音频输出(比如,电脑正在播放视频的声音),或录制外部环境音频输入(比如,自己说话的声音) 1.录制电脑音频输出 在“硬件”选项中,将”选中设备的设 ...
- [1] Report Fusioncharts
图形报表之fusioncharts