Oracle中update和select 关联操作
程序员文章站
2022-06-10 08:33:01
目录1、介绍2、解决方法2.1、需求2.2、错误演示2.3、解决方法1、介绍本文主要向大家介绍了oracle数据库之oracle update set select from 关联更新,通过具体的内容...
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)进行相应记录的匹配更新,一次只能是一条。
到此这篇关于oracle update和select 关联的文章就介绍到这了,更多相关oracle update和select 关联内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
下一篇: 关于url,src,href的区别联系
推荐阅读
-
sqlserver中delete、update中使用表别名和oracle的区别
-
在oracle 数据库查询的select 查询字段中关联其他表的方法
-
SQL server 和 Oracle 中列转行的小操作
-
在Window中Oracle中修改用户名和密码的操作方法
-
MySQL中Update、select联用操作单表、多表,及视图与临时表的区别
-
Oracle中多表关联批量插入批量更新与批量删除操作
-
C#中枚举类型和radiobox关联操作的方法
-
mysql 同一个表不能同时进行update 和select 操作 已看过网上写法但还是有错
-
Oracle中select 1和select *的区别
-
select...for update在mysql和oracle间锁行为的比较_MySQL