数据库技术:Oracle中update和select 关联操作

目录1、介绍2、解决方法2.1、需求2.2、错误演示2.3、解决方法1、介绍本文主要向大家介绍了oracle数据库之oracle update set select from 关联更新,通过具体的内容

目录
  • 1、介绍
  • 2、解决方法
    • 2.1、需求
    • 2.2、错误演示
    • 2.3、解决方法

1、介绍

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

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

goods表:

select gid,code,name,code2 from goods; 

Oracle中update和select 关联操作

init_goods表:

select code,name,code2 from init_goods;

Oracle中update和select 关联操作

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)进行相应记录的匹配更新,一次只能是一条。

到此这篇关于oracle update和select 关联的文章就介绍到这了,更多相关oracle update和select 关联内容请搜索<猴子技术宅>以前的文章或继续浏览下面的相关文章希望大家以后多多支持<猴子技术宅>!

需要了解更多数据库技术:Oracle中update和select 关联操作,都可以关注数据库技术分享栏目—猴子技术宅(www.ssfiction.com)

本文来自网络收集,不代表猴子技术宅立场,如涉及侵权请点击右边联系管理员删除。

如若转载,请注明出处:https://www.ssfiction.com/sqljc/1031441.html

发表评论

邮箱地址不会被公开。 必填项已用*标注