oracle 批量更新之将一个表的数据批量更新至另一个表
oracle 批量更新之将一个表的数据批量更新至另一个表
CreationTime--2018年7月3日17点38分
Author:Marydon
Oracle 将一个表的指定字段的值更新至另一个表的对应字段
案例一:
1.情景描述
testdata表数据展示

testdata2表数据展示

数据对比:
testdata表有31条数据,且有9条数据的userid与testdata2表不一致(自己独有);
testdata2表有24条数据,且有2条数据的userid与testdata2表不一致(自己独有)。
表关联:testdata表和testdata2表的userid具有关联关系
需求说明:
需要将testdata中的22条数据更新到testdata2表中
2.错误方式
这种方式,由于没有设置更新的限制条件,导致:
不仅会更新需要更新的表记录,还会将testdata2中剩余的数据字段更新为空。

3.解决方案
添加where条件,只对两表共有的数据进行更新。
2018/12/05
正确格式:
UPDATE TABLE1 T1
SET (T1.COLUMN1, T1.COLUMN2) =
(SELECT T2.COLUMN1, T2.COLUMN2 FROM TABLE2 T2 WHERE T2.ID = T1.ID) --两表能够进行关联的字段(一般是主键)
WHERE EXISTS (SELECT 1 FROM TABLE2 T2 WHERE T2.ID = T1.ID);
错误格式:
UPDATE TABLE1 T1
SET (T1.COLUMN1, T1.COLUMN2) =
(SELECT T2.COLUMN1, T2.COLUMN2 FROM TABLE2 T2 WHERE T2.ID = T1.ID)
WHERE EXISTS (SELECT 1 FROM TABLE1 T1 WHERE T1.ID = T2.ID);--exists()访问不到t2表
说明:虽然理论上,它们执行效果是一样的,但是由于exists()函数访问不到t2表,所以查询访问不到的那张表t2。
套用
--添加限制条件,进行更新
update testdata2 t2
set (t2.usercode, t2.userpassword) =
(select t.usercode, t.userpassword
from testdata t
where t.userid = t2.userid)
where exists (select 1 from testdata t where t.userid = t2.userid);

避免了全表更新。
2018/12/07
案例二:
4.索引的重要性
更新1w条以上的数据时,where后面跟的条件一定要加上索引,不然哭都来不及。
需要更新22w条数据,两张表的ID_CARD字段没有建索引

两张表的ID_CARD字段建立索引后

这是我的亲身经历,没有建索引前,执行了4个小时,没有更新完,后来由于电脑关机,导致任务终止;
建索引后,同样执行该sql,更新22w条数据只用了4秒!!!
说明:对于要执行的更新sql,使用plsql的预测功能时预测不准确,只做参考。
2019/01/10
案例三:
将VIRTUAL_CARD表中的ADDRESS字段数据更新至TEST_CARD表中的ADDRESS字段
方式一:sql实现
UPDATE TEST_CARD T
SET T.ADDRESS =
(SELECT T2.ADDRESS FROM VIRTUAL_CARD T2 WHERE T.CARDNUM = T2.CARDNUM)
WHERE EXISTS (SELECT 1 FROM VIRTUAL_CARD T2 WHERE T2.CARDNUM = T.CARDNUM)
方式二:借助plsql工具
将要更新的表的rowid查询出来,并获取最后页

编辑数据--》选中Address字段所有数据

右键--》复制--》选中第一列的Address所有数据--》粘贴

勾选上图绿色勾,提交即可。

说明:
大批量修改数据时,推荐使用方式一更新;
少量数据修改时,两种方式均可。
5.总结
A表中有几个字段的值需要批量更新,如果一个一个进行修改,太慢了:
将批量修改后的内容放到一个新的表中B,并与要更新的表A建立关联关系。
第一步:建新表
两表关联字段(column1):A表中该字段必须具有唯一性;
要更新的字段(column5,cloumn6,...)。
第二步:导数据
将新表字段及每条记录更新后内容放到excel中,导入oracle数据库中B表。
第三步:根据两表关联关系,将B表数据批量更新到A表中。
oracle 批量更新之将一个表的数据批量更新至另一个表的更多相关文章
- mysql中把一个表的数据批量导入另一个表中
mysql中把一个表的数据批量导入另一个表中 不管是在网站开发还是在应用程序开发中,我们经常会碰到需要将MySQL或MS SQLServer某个表的数据批量导入到另一个表的情况,甚至有时还需要指定 ...
- ORACLE 查询一个数据表后通过遍历再插入另一个表中的两种写法
ORACLE 查询一个数据表后通过遍历再插入另一个表中的两种写法 语法 第一种: 通过使用Oracle语句块 --指定文档所有部门都能查看 declare cursor TABLE_DEPT and ...
- 使用POI把查询到的数据表数据导出到Excel中,一个表一个sheet.最详细!!!
一.需求 我们会遇到开发任务: 经理:小王,你来做一下把数据库里的数据导出到Excel中,一个表是一个sheet,不要一个表一个Excel. 小王:好的,经理.(内心一脸懵逼) 二.前期准备 首先我们 ...
- 一条sql解决.一张表的数据复制到另外一张表
如何把一个表的数组复制到一张表?也许很多人会把这个表查出来的数据再插入到另外一张表里面,这样很麻烦又要写代码逻辑去处理,其实一条sql语句就可以把一张表的数据复制到另外一张表,或者一张表的某一条数据复 ...
- hive sql 查询一张表的数据不在另一张表中
有时,我们需要对比两张表的数据,找到在其中一张表,不在另一张表中的数据 hql 如下: SELECT * FROM (SELECT id FROM a WHERE dt = '2019-03-17' ...
- oracle triggers 实现两个结构相同的表的数据级联更新操作
首先创建两个结构相同的表 -- Create table create table TABLE_TEMP ( userid NUMBER not null, username NVARCHAR2(50 ...
- 在oracle中怎么把一张表的数据插入到另一张表中
把table2表的数据插入到table1中 insert into table1 select * from table2
- SQL从一个表查询数据插入/更新到另一个表
示例一: 从数据库表A中查询出数据插入到数据库表B 从数据库DataBaseA的表TDA中查询出数据插入到数据库DataBaseB的表TDB insert into [DataBaseA].[dbo] ...
- 通过mapreduce把mysql的一张表的数据导到另外一张表中
怎么安装hadoop集群我在这里就不多说了,我这里安装的是三节点的集群 先在主节点安装mysql 启动mysql 登录mysql 创建数据库,创建表格,先把数据加载到表格 t ,表格t2是空的 mys ...
随机推荐
- [asp.net web api] HttpStatusCode的使用
摘要 在开放api的时,我们需要返回不同的状态给调用方,以告诉它们当前请求的结果,是成功了还是失败了.当然这种给调用方的反馈有很多种做法,这里就说是web api内置的对Http状态码.http状态码 ...
- 基于curl的异步http实现
简述用于windowsclient的一个异步http模块的实现 1.须要实现的feature 1.1 非常easy地发起异步http请求,然后回调. 1.2 可以管理http并发数. 1.3 可以支持 ...
- 测试 Nginx 作为前端下各种模式的性能
测试环境: 1:Nginx 独立处理静态面页请求 5000,开了60个线程 2:Nginx作为前端请求转给 Weblogic 12c 处理 (Spring 4.0平台下的动态面页效果如图) 3:Ngi ...
- Git remotes/origin/pr/* 分支清理
代码在gitHub上托管,每次git pull完后,用git branch -a都可以看到一堆remotes/origin/pr/*分支: 可以通过两种方式去除: 1,修改git的config文件找到 ...
- Latex 初学者入门(四)-- 多个作者共享同一个地址
又给老板改格式,其实感觉大多会议都是模板不同,不同主要在于注释,作者,摘要以及引用文献的不同,上次的那篇讲bib数据库的用法,真是倒腾了一整天,不知道为什么一定要使用这种东西,而且老板貌似对人家的风格 ...
- maven依赖信息获取
1.mvn dependency:analyze 首先是"Used declared dependencies found",指项目中使用到,但是没有显示声明的依赖,如果有的话,需 ...
- poj 2585 Window Pains 解题报告
Window Pains Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2027 Accepted: 1025 Desc ...
- hbase数据模型以及编码压缩(转)
原文链接:hbase源码系列(四)数据模型-表定义和列族定义的具体含义 hbase是一个KeyValue型的数据库,在<hbase实战>描述它的逻辑模型[行键,列族,列限定符,时间版本], ...
- fpga状态机详解
什么是状态机:状态机通过不同的状态迁移来完成特定的逻辑操作 状态机的分类:Moore型状态机和Mealy型状态机 Moore型:状态机的变化只与当前的状态有关 Mealy型:状态机的变化不仅与当前的状 ...
- 你对position的了解有多少?
此文根据Steven Bradley的<How Well Do You Understand CSS Positioning?>所译,整个译文带有我自己的理解与思想,如果译得不好或不对之处 ...