Oracle update和select 关联

1、介绍

本文主要向大家介绍了Oracle数据库之oracle update set select from 关联更新,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助。

工作中有个需求,现在新表中有一些数据跟老表的基本一样,这样只需要把老表中数据搬到新表中就可以了,同时把不同的字段修改下数据即可,在修改字段时发现,需要指定一个条件,比如主键id,来修改某条记录,这样一条一条修改效率太低了,有没有批量操作的方式呢?

goods表:

select gid,code,name,code2 from goods;

init_goods表:

select code,name,code2 from init_goods;

2、解决方法

2.1、需求

goods表中code2根据init_goods表中code2更新;

2.2、错误演示

下面是一个错误的做法:

update goods set code2 =
(select code2 from init_goods where init_goods.code = goods.code)

goods表数据无法更新,系统会一直卡主,知道崩溃;

2.3、解决方法

方法一:

update goods set code2 =
(select code2 from init_goods where init_goods.code = goods.code)
where exists (select 1 from init_goods where init_goods.code = goods.code)

方法二:

update goods goods
set goods.code2 = (select init_goods.code2 from init_goods where init_goods.code = goods.code)
where goods.code = (select init_goods.code from init_goods where init_goods.code = goods.code)

注意:修改的列是code2,条件是 code ;

说明:

如果select 子句可以返回多行记录,但返回适合where条件的记录是唯一的,否则将会报返回单行的select子句返回多行的错误,因为 update只能跟据此处的where子句(内层where)进行相应记录的匹配更新,一次只能是一条

最新文章

  1. Mysql - 性能优化之子查询
  2. highcharts使用笔记
  3. Unity3D手游开发实践
  4. MVC – 3.EF(Entity Framework)
  5. Linux系统巡检常用命令
  6. 手把手教你 用 wpf 制作metro ProgressRing (Windows8 等待动画)
  7. objective-c 随便记记
  8. (C#) System.BadImageFormatException: An attempt was made to load a program with an incorrect format.
  9. asp.net使用httphandler打包多CSS或JS文件以加快页面加载速度
  10. Subset leetcode java
  11. DIV+CSS相对IE8的兼容问题
  12. php 写一个水仙花数的函数
  13. 持续集成环境Jenkins的搭建和使用
  14. scribefire 多博客管理利器 安装详解
  15. c++读取REG_MULTI_SZ类型注册表
  16. java.sql.SQLException: Can not issue empty query.
  17. delphi 验证码识别(XE8源码)
  18. Android Material Design控件使用(一)——ConstraintLayout 约束布局
  19. 把路由器改装成git服务器(OpenWRT环境的GIT服务器搭建)
  20. ajax请求code:200但是进入error函数

热门文章

  1. 突出显示(Project)
  2. CF570A Elections 题解
  3. libevent源码学习(15):信号event的处理
  4. tmux技巧
  5. JAVA获取当前日期所在的周一到周日的所有日期集合
  6. 【剑指Offer】二叉树中和为某一值的路径 解题报告(Python)
  7. LeetCode1240铺瓷砖
  8. Rectangles(hdu2461)
  9. eclipse的安装及最大子数组求和
  10. Mac下搭建基于PlatformIO的嵌入式开发环境(STM32开发)