基本需求:
老数据有老数据的顺序编码规则,新数据有新数据的顺序编码规则,但是老数据的编码还是要更新相应的东西,新数据也得实时更新,在新数据中已经用新编码规则对老数据对进行编码,在上报表中既要新增新数据,也要更新老数据与现有数据。
-------------------------------------------------
--Author:Oliver QIN
--Date:2015-11-07
--DESC:使用映射表对老数据进行更新
-------------------------------------------------
--存储老数据的表
--drop table TB_old
CREATE TABLE TB_old(Id INT,IdSeq VARCHAR(20),Name VARCHAR(200),Adress varchar(200),Age int)
--------------------------------------------------------------------
--插入测试数据(2014年的人员信息表)
---目前的编号是以省份来编号的,例如下面插入的测试数据 /*************************老的人力资源管理系统中******************************/ INSERT INTO TB_old SELECT 1,'yunnan01','JACK','云南昆明',45 union all
SELECT 2,'yunnan02','Tom','云南曲靖',82 union all
SELECT 3,'yunnan03','Alice','云南丽江',60 union all
SELECT 4,'yunnan04','Jerry','云南昭通',26 union all
SELECT 5,'chongqin05','Terry','重庆江北',22 ---随着时间的变迁,需要把编号进行修改,统一为China开头的编号,例如:China01 --那接着就建立映射表
/*********************************映射表***************************************/
--drop table Mapping
CREATE TABLE Mapping (Old_IdSeq varchar(100),New_IdSeq varchar(100))
--插入映射关系 insert into Mapping select 'yunnan01','China01' union all
select 'yunnan02','China02' union all
select 'yunnan03','China03' union all
select 'yunnan04','China04' union all
select 'chongqin05','China05' ---这是2015年在新人力资源管理系统中新生成的一张信息表 注明:在老系统中已经生成的编号不可以替换成现有编号,需要延用至退休
--drop table TB_New 注:新的人力资源表中JACK的年龄更新为99,并且新加了JOSN的相关信息
CREATE TABLE TB_New(Id INT,IdSeq VARCHAR(20),Name VARCHAR(200),Adress varchar(200),Age int) --插入新的测试数据
/*************************新的人力资源管理系统中******************************/ INSERT INTO TB_New SELECT 1,'China01','JACK','云南昆明',99 union all
SELECT 2,'China02','Tom','云南曲靖',82 union all
SELECT 3,'China03','Alice','云南丽江',60 union all
SELECT 4,'China04','Jerry','云南昭通',26 union all
SELECT 5,'China05','Terry','重庆江北',22 union all
SELECT 6,'China06','JOSN','广东深圳',25
-------------现在有如下需求
/*********************************************************
随着时间的推移,需要实时的更新他们的相关信息,假设录入该年龄的时间是2014年
2015年系统进行升级,录入的相关信息则按新的规则命名编号,如果年龄大于45岁则不更新相关信息,视为退休
新的系统中已经把老的信息按照新的编码规则进行编码,但是这些信息需要用来上报给总经理查看。 */ /**************************上报数据库中的信息*******************************************/ /*上报库中的信息是以前老的系统中的数据*/
--drop table Report_Rpt CREATE TABLE Report_Rpt(Id INT,IdSeq VARCHAR(20),Name VARCHAR(200),Adress varchar(200),Age int) INSERT INTO Report_Rpt select * from TB_old
/**************************************************************************************
要求:使用新的人力资源管理系统中提供的数据对更新上报信息中的年龄
*/
--建立映射视图,用于关联更新
go
--select * from Differrence_Data
CREATE VIEW Differrence_Data
as
select A.Age,B.Old_IdSeq from TB_New A
left join Mapping B ON A.IdSeq=B.New_IdSeq
left join TB_old C ON C.IdSeq=B.Old_IdSeq
WHERE A.Age<>C.Age
--------------------------------------------------------- GO
--DROP PROC Get_NewInfo
CREATE PROC Get_NewInfo
AS
BEGIN
-------------------------------------------------------情况一:更新老编码对应的年龄信息
if((select COUNT(*) from Differrence_Data)>0)
-------------------------如果在视图Differrence_Data中存在数据,那么更新相应的老编码信息
UPDATE Report_Rpt SET Age=A.Age FROM Differrence_Data A WHERE A.Old_IdSeq=Report_Rpt.IdSeq IF ( (select COUNT(1) from TB_New where IdSeq not in
(SELECT New_IdSeq FROM Mapping
union all
select IdSeq FROM Report_Rpt
)
) >0
)
-------------------------------------------------情况二:将新增的数据插入到上报表中
---插入新增的数据到上报信息表中
insert into Report_Rpt
select * from TB_New A WHERE A.IdSeq NOT IN (SELECT New_IdSeq FROM Mapping
UNION all
select IdSeq FROM Report_Rpt) ------------------------------------------------情况三:更新新编码对应的年龄信息
IF (
(SELECT COUNT(1) FROM TB_New WHERE
IdSeq not in
(select New_IdSeq from Mapping)
AND IdSeq IN
(SELECT IdSeq FROM Report_Rpt)
)>0
)
--------------------更新新增加数据年龄变更的信息
UPDATE Report_Rpt SET Age=A.Age FROM TB_New A WHERE
A.IdSeq not in
(select New_IdSeq from Mapping)
AND A.IdSeq IN
(SELECT IdSeq FROM Report_Rpt)
AND A.IdSeq = Report_Rpt.IdSeq END --执行存储过程
EXEC Get_NewInfo --老人力资源表
select * from TB_old
--新人力资源表
select * from TB_New
--映射表
select * from Mapping
--上报表
select * from Report_Rpt
--------------------------------------------
--删除表语句
--DROP TABLE TB_old,TB_New,Mapping,Report_Rpt --------------------------------以下是测试老编码年龄变化跟新编码年龄变化还有新增新的人员信息时,是否也会更新跟插入相应的数据 --------------------------------------改变新人力资源系统中的数据进行逻辑测试
insert into TB_New SELECT 7,'China07','测试01','云南昆明',21 union all
SELECT 8,'China08','测试02','云南昆明',33
---------------修改新数据进行测试
update TB_New set Age='' where Id=''
---------------修改老数据的年龄进行测试
update TB_New set Age='' where Id=''

SQLserver使用映射表进行数据相关操作的更多相关文章

  1. CockroachDB学习笔记——[译]CockroachDB中的SQL:映射表中数据到键值存储

    CockroachDB学习笔记--[译]CockroachDB中的SQL:映射表中数据到键值存储 原文标题:SQL in CockroachDB: Mapping Table Data to Key- ...

  2. 背景:表A数据误操作,被delete了,恢复。

    SELECT MAX(Scn) FROM Sys.Smon_Scn_Time WHERE Time_Dp < TO_DATE('2015-09-18', 'YYYY/MM/DD') select ...

  3. c数据结构 顺序表和链表 相关操作

    编译器:vs2013 内容: #include "stdafx.h"#include<stdio.h>#include<malloc.h>#include& ...

  4. MySQL的数据库,数据表,数据的操作

    数据库简介 概念 什么是数据库?简单来说,数据库就是存储数据的"仓库", 但是,光有数据还不行,还要管理数据的工具,我们称之为数据库管理系统! 数据库系统 = 数据库管理系统 + ...

  5. sqoop导入数据到hive表中的相关操作

    1.使用sqoop创建表并且指定对应的hive表中的字段的数据类型,同时指定该表的分区字段名称 sqoop create-hive-table --connect "jdbc:oracle: ...

  6. mysql 5.7 laravel json类型数据相关操作

    2018年10月16日18:14:21 官方文档中文翻译版 原文:https://dev.mysql.com/doc/refman/5.7/en/json.html 最后有部分实例和一个小总结 11. ...

  7. workbook数据相关操作

    访问单个单元格 c = ws['A4'] #返回单元格A4,如果单元格不存在,则会自动创建 ws['A4'] = 4 #为单元格A4赋值为4 d = ws.cell(row=4, column=2, ...

  8. 查询sqlserver数据库,表占用数据大小

     if exists(select 1 from tempdb..sysobjects where id=object_id('tempdb..#tabName') and xtype='u')dro ...

  9. MySql学习笔记【四、数据相关操作】

    CURD--增改查删 创建数据 INSERT [INTO] tb_name [(col_name,...)] VALUES(val,..) 若列名缺省,表示插入全部列,也可指定部分列名 如: INSE ...

随机推荐

  1. 翻译的技巧(The Technique of Translation)——前言

    曰:你要发文章才能毕业! 答:谨遵圣命-- 缘起 研三了,要找工作了,要离开学校了,又要像浮萍般飘荡在世上了,还是学校好呀!本以为写个毕业论文就可以了,谁知老板幽幽地说写篇文章发了吧.我竟无言以对.不 ...

  2. Centos6.5 minicom安装与配置

    Linux下的Minicom的功能与下的超级终端功能相似,适于在通过超级终端对设备的管理以及对嵌入操作系统的升级 1.minicom的安装 查看是否安装:   rpm -qa | grep minic ...

  3. ognl.NoSuchPropertyException

    [WARN ] 2013-11-21 14:56:25 :Error setting expression 'b2bAccOcPage.endB2bGrantDateString' with valu ...

  4. php get传递数据

    url:?goods[]=924&goods[]=967&goods[]=993 <?php  if($_GET){            print_r($_GET);  } ...

  5. python和php对比

    对php比较熟悉,最近开始学些python,总是搞混,特记录下来,用于熟悉python:1.python数组和php不同,php相对简单统一,即array(包括普通数组和关联数组两部分),python ...

  6. linux中ll和du的区别

    首先,明确一个概念,linux中目录其实也是一个文件,它存储了一张表,该表就是该目录文件下,所有文件名和inode的映射关系. 其中inode和数据块block的关系http://c.bianchen ...

  7. jquery递归遍历xml文件,形成ul-li序列,生成树结构(使用了treeview插件)

    treeview插件从这里获得,下载的文件中有demo,看demo文件夹里面的index.html文件就差不多知道如何使用该控件了,在我做的项目里用到的部分代码截图如下(在引用下面的js文件前要先引用 ...

  8. java基础回顾(五)——Stack、Heap

    栈(stack):是简单的数据结构,但在计算机中使用广泛.栈最显著的特征是:LIFO(Last In, First Out,后进先出).比如我们往箱子里面放衣服,先放入的在最下方,只有拿出后来放入的才 ...

  9. XSS CSRF 攻击

    XSS:跨站脚本(Cross-site scripting) CSRF:跨站请求伪造(Cross-site request forgery)定义: 跨网站脚本(Cross-site scripting ...

  10. poj1006_Biorhythms

    英语真差劲啊,看题目没看明白,无奈重新开始手抄题目,突然发现一句话 “For each cycle,you will be given the number of days form the begi ...