将一个表的字段更新到另一个表中去

描述

做一个需求需要记录用户留下签字意见时的职位信息,并且签字意见中留下的职位信息不随他的职位的调动变化而变化。在标准产品的签字意见表里面没有记录职位信息的字段,这就需要我们添加一个字段用于存储当前操作者的职位信息,对于新的数据我们可以在插入签字意见的时候一并插入。但是对于历史数据,我们就需要通过SQL来更新,这样在升级客户系统的时候直接运行一个SQL脚本就将历史数据的职位字段更新为记录的操作者当前的职位信息。

假设表HRM表示用户表,结构如下:

字段名字 类型 备注
ID NUMBER 用户id
NAME VARCHAR2 用户名字
DEPT NUMBER 部门id

签字意见表LOG,结构如下:

字段名字 类型 备注
ID NUMBER 签字意见id
USERID NUMBER 用户id
DEPT NUMBER 部门id
LOG VARCHAR2 签字意见内容

数据库使用的是oracle11g,测试表创建脚本:

CREATE TABLE HRM (
  ID NUMBER NOT NULL ,
  NAME VARCHAR2(255 BYTE) ,
  DEPT NUMBER
)

CREATE TABLE LOG (
  ID NUMBER NOT NULL ,
  USERID NUMBER ,
  DEPT NUMBER ,
  LOG VARCHAR2(255 BYTE)
)

INSERT INTO "HRM"("ID", "NAME", "DEPT") VALUES (‘1‘, ‘zx‘, ‘22‘);
INSERT INTO "HRM"("ID", "NAME", "DEPT") VALUES (‘2‘, ‘wj‘, ‘22‘);
INSERT INTO "HRM"("ID", "NAME", "DEPT") VALUES (‘3‘, ‘lk‘, ‘33‘);
INSERT INTO "HRM"("ID", "NAME", "DEPT") VALUES (‘4‘, ‘po‘, ‘44‘);
INSERT INTO "HRM"("ID", "NAME", "DEPT") VALUES (‘5‘, ‘mm‘, ‘55‘);
INSERT INTO "HRM"("ID", "NAME", "DEPT") VALUES (‘6‘, ‘jz‘, ‘66‘);
INSERT INTO "HRM"("ID", "NAME", "DEPT") VALUES (‘7‘, ‘ui‘, ‘77‘);

INSERT INTO "LOG"("ID", "USERID", "DEPT", "LOG") VALUES (‘1‘, ‘1‘, NULL, ‘xx‘);
INSERT INTO "LOG"("ID", "USERID", "DEPT", "LOG") VALUES (‘2‘, ‘1‘, NULL, ‘xxx‘);
INSERT INTO "LOG"("ID", "USERID", "DEPT", "LOG") VALUES (‘3‘, ‘2‘, NULL, ‘sss‘);
INSERT INTO "LOG"("ID", "USERID", "DEPT", "LOG") VALUES (‘5‘, ‘3‘, NULL, ‘ss‘);
INSERT INTO "LOG"("ID", "USERID", "DEPT", "LOG") VALUES (‘6‘, ‘3‘, NULL, ‘ss‘);
INSERT INTO "LOG"("ID", "USERID", "DEPT", "LOG") VALUES (‘7‘, ‘4‘, NULL, ‘sss‘);

者两个表之间通过HRM表的ID和LOG表的USERID进行关联,现在需要将LOG表的历史记录中的DEPT字段更新为他的userid对应的HRM表的DEPT字段的值。方法如下所示。

方法一

update LOG SET (dept) = (select dept from HRM where id = LOG.userid)

方法二

merge into LOG using HRM on (LOG.USERID = HRM.ID)
when matched
then update set LOG.DEPT = HRM.DEPT

参考

1.oracle怎么用一个表的多个字段数据更新另一个表相应的字段中

2.Oracle中Merge into用法总结

原文地址:https://www.cnblogs.com/ZiYangZhou/p/8185932.html

时间: 2024-11-09 00:45:56

将一个表的字段更新到另一个表中去的相关文章

UPDATE语句:将一个表里的字段更新到另一个表的字段里的语句

update table2 b,(select b.area_id as arid,sum(a.user_amount) as bcount from table1 a,table2 b where a.user_area=b.area_id group by arid) c set b.count=c.bcount where b.area_id=c.arid;

Oracle中用一张表的字段更新另一张表的字段

今天在做项目的过程中,发现开发库中某张表的某字段有许多值是空的,而测试库中该字段的值则是有的. 那么,有什么办法能将测试库中该字段的值更新到开发库中呢? SQL Server中这是比较容易解决的,而Oracle中就不知道方法了. SQL Server中类似问题的解决方法 后来只好用最笨的方法: 首先,将数据复制到Excel:(假设称测试库的表为A--含有数据) 然后,在开发库中建立和表A同结构的表B:(这里为了导入数据的简单,我对表B的结构进行了改造,只有两个字段) 图 表B的数据 再利用PL

mysql把一个表的字段update成另一个表的字段根据id

1.填充activity表里面的creator字段,用org的founderid,其中activity的orgid要和org的id对应,具体sql语句如下:update activity a inner join (select id,founderid from org o) c on a.orgid =c.id  set a.creator = c.founderid;

SQL两表之间:根据一个表的字段更新另一个表的字段

1. 写法轻松,更新效率高: update table1 set field1=table2.field1, field2=table2.field2 from table2 where table1.id=table2.id 2. 常规方式,种写法相当于一个 Left join, 以外面的where为更新条数,如果不加where就是所有记录 update table1 set field1=(select top 1 field1 from table2 where table2.id=tab

MySql中把一个表的数据插入到另一个表中的实现代码--转

MySql中把一个表的数据插入到另一个表中的实现代码 司的一个项目,做报表--要关联的表结构比较多,最后决定把要用的数据集合到一张新表中,需要用到以下的sql语法......分享下: web开发中,我们经常需要将一个表的数据插入到另外一个表,有时还需要指定导入字段,设置只需要导入目标表中不存在的记录,虽然这些都可以在程序中拆分成简单sql来实现,但是用一个sql的话,会节省大量代码.下面我以mysql数据库为例分情况一一说明: 1.如果2张表的字段一致,并且希望插入全部数据,可以用这种方法: ?

mysql中把一个表的数据批量导入另一个表中(不同情况)

mysql中把一个表的数据批量导入另一个表中 不管是在网站开发还是在应用程序开发中,我们经常会碰到需要将MySQL某个表的数据批量导入到另一个表的情况,甚至有时还需要指定导入字段. 本文就将以MySQL数据库为例,介绍如何通过SQL命令行将某个表的所有数据或指定字段的数据,导入到目标表 中. 类别一. 如果两张张表(导出表和目标表)的字段一致,并且希望插入全部数据,可以用这种方法:(此方法只适合导出两表在同一database) INSERT INTO 目标表 SELECT * FROM 来源表;

将一个列表的数据复制到另一个列表中

1 ''' 2 提问:将一个列表的数据复制到另一个列表中. 3 请仔细看要求,这里要求的是复制数据到一个新的列表中. 4 Python列表数据复制,Python解题思路分析:可以了解下[ :]的含义 5 ''' 6 l = [1,2,3,4] 7 x = l[:] # x = l.copy() 8 print(x) 原文地址:https://www.cnblogs.com/JerryZao/p/8678880.html

练习七:列表复制(将一个列表的数据复制到另一个列表中)

习题七:将一个列表的数据复制到另一个列表中. 1 list1 = [1,2,3,4,5,8] 2 3 list2 = list1[:] #直接赋值,使用: 浅复制 4 5 list3 = list1 #直接赋值,相当于浅复制 6 7 import copy #使用copy模块,深复制 8 list4 = copy.copy(list1) 9 10 list5 = list1.copy() #使用copy函数 潜复制 11 12 print(list1,list2,list3,list4,list

SQL实现将一个表的数据插入到另外一个表的代码

--第一种情况的 1>如果2张表的字段一致,并且希望插入全部数据,可以用这种方法: INSERT INTO 目标表 SELECT * FROM 来源表; 2>比如要将 articles 表插入到 newArticles 表中,则是: INSERT INTO newArticles SELECT * FROM articles; 3>如果只希望导入指定字段,可以用这种方法: INSERT INTO 目标表 (字段1, 字段2, ...) SELECT 字段1, 字段2, ... FROM