SQLserver使用映射表进行数据相关操作
基本需求:
老数据有老数据的顺序编码规则,新数据有新数据的顺序编码规则,但是老数据的编码还是要更新相应的东西,新数据也得实时更新,在新数据中已经用新编码规则对老数据对进行编码,在上报表中既要新增新数据,也要更新老数据与现有数据。
-------------------------------------------------
--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使用映射表进行数据相关操作的更多相关文章
- CockroachDB学习笔记——[译]CockroachDB中的SQL:映射表中数据到键值存储
CockroachDB学习笔记--[译]CockroachDB中的SQL:映射表中数据到键值存储 原文标题:SQL in CockroachDB: Mapping Table Data to Key- ...
- 背景:表A数据误操作,被delete了,恢复。
SELECT MAX(Scn) FROM Sys.Smon_Scn_Time WHERE Time_Dp < TO_DATE('2015-09-18', 'YYYY/MM/DD') select ...
- c数据结构 顺序表和链表 相关操作
编译器:vs2013 内容: #include "stdafx.h"#include<stdio.h>#include<malloc.h>#include& ...
- MySQL的数据库,数据表,数据的操作
数据库简介 概念 什么是数据库?简单来说,数据库就是存储数据的"仓库", 但是,光有数据还不行,还要管理数据的工具,我们称之为数据库管理系统! 数据库系统 = 数据库管理系统 + ...
- sqoop导入数据到hive表中的相关操作
1.使用sqoop创建表并且指定对应的hive表中的字段的数据类型,同时指定该表的分区字段名称 sqoop create-hive-table --connect "jdbc:oracle: ...
- mysql 5.7 laravel json类型数据相关操作
2018年10月16日18:14:21 官方文档中文翻译版 原文:https://dev.mysql.com/doc/refman/5.7/en/json.html 最后有部分实例和一个小总结 11. ...
- workbook数据相关操作
访问单个单元格 c = ws['A4'] #返回单元格A4,如果单元格不存在,则会自动创建 ws['A4'] = 4 #为单元格A4赋值为4 d = ws.cell(row=4, column=2, ...
- 查询sqlserver数据库,表占用数据大小
if exists(select 1 from tempdb..sysobjects where id=object_id('tempdb..#tabName') and xtype='u')dro ...
- MySql学习笔记【四、数据相关操作】
CURD--增改查删 创建数据 INSERT [INTO] tb_name [(col_name,...)] VALUES(val,..) 若列名缺省,表示插入全部列,也可指定部分列名 如: INSE ...
随机推荐
- "开发路上踩过的坑要一个个填起来————持续更新······(7月30日)"
欢迎转载,请注明出处! https://gii16.github.io/learnmore/2016/07/29/problem.html 踩过的坑及解决方案记录在此篇博文中! 个人理解,如有偏颇,欢 ...
- Android开发-API指南-Fragment
Fragments 英文原文:http://developer.android.com/guide/components/fragments.html 采集日期:2014-12-31 在本文中 设计理 ...
- 在git 服务器挂载新的项目
1.cmd 到新创建的文件夹位置,然后 执行该命令git init --bare 2.在客户端克隆项目到文件夹(空),将项目复制到该空文件夹下,然后打开git extent,提交并推送
- Duilib学习笔记《05》— 消息响应处理
在Duilib学习笔记<04>中已经知道了如何将窗体显示出来,而如何处理窗体上的事件.消息呢? 一. 系统消息 窗体显示的时候我们就已经说了,窗体是继承CWindowWnd类的,对于窗体的 ...
- C++中rapidxml用法及例子
rapidxml是一个快速的xml库,比tinyxml快了50-100倍.本文给出创建.读取.写入xml的源码. 由于新浪博客不支持文本文件上传,在使用下面代码需要先下载 rapidxml,关于这个库 ...
- c# 字符串(含有汉字)转化为16进制编码(转)
public static string Str2Hex(string s) { string result = string.Empty; byte[] arrByte = System.Text. ...
- Linux命令之type
1:linux命令可以分为很多类,其中常见得类型: (1):builtin --内置命令 (2):alias --命令别名 (3):file --外部命令 具体有哪些内置命令以及内置命令各个用法: [ ...
- Android开发教程 录音和播放
首先要了解andriod开发中andriod多媒体框架包含了什么,它包含了获取和编码多种音频格式的支持,因此你几耍轻松把音频合并到你的应用中,若设备支持,使用MediaRecorder APIs便可以 ...
- Ubuntu系统使用记录(持续更新)
本篇文章记录在虚拟机上跑Ubuntu16.04遇到的一系列问题,熟悉一下Ubuntu的相关操作,进入终端的方法ctrl+alt+t. 1.修改屏幕分辨率,进入系统默认的是800x600 即便能够进入s ...
- 树莓派 B+ Yeelink实现图像监控
树莓派 B+ Yeelink实现图像监控 数值传感器请参考 : http://blog.csdn.net/xiabodan/article/details/39084877 1 安装摄像头 ...