Oracle 数据库 根据B表的数据更新A表

简介: Oracle 数据库 根据B表的数据更新A表

1、语句

update A set A.字段2 =(select B.idfrom B where A.字段2 = B.字段2)where exists (select1from B where B.字段2 = A.字段2);-- 如果B表字段2有重复,那么会报错:单条语句返回多行。此时用下面语句: update A set A.字段2 =(select B.idfrom B where A.字段2 = B.字段2 and rownum=1)where exists (select1from B where B.字段2 = A.字段2);

2、exists

exists :存在,出现,活着。

1、exists 字面意思存在。

EXISTS里的子查询结果集非空,EXISTS()子句的值就是true。

EXISTS里的子查询结果集为空,EXISTS()子句的值就是false。

SELECT*FROM SCOTT.EMPWHERE EXISTS(SELECT SYSDATE FROM DUAL);// 括号里面部分成立,也就是true

此句将查出scott.emp表所有内容.

SELECT * FROM SCOTT.EMP WHERE EXISTS(SELECT * FROM scott.salgrade where 1=2) ; // 1 = 2 不成立,

返回空结果集

参考一下论述:

 带有EXISTS谓词的子查询不返回任何数据,只产生逻辑真值“true”或逻辑假值“false”。

 使用存在量词EXISTS后,若内层查询结果非空,则外层的WHERE子句返回真值否则返回假值。

 由EXISTS引出的子查询,其目标列表达式通常都用*,因为带EXISTS的子查询只返回真值或假值,

 给出列名无实际意义。

用exists的相关子查询明白相关子查询:  

子查询的查询条件依赖于外层父查询的某个属性值,称这类查询为相关子查询。  

求解相关子查询不能像求解不相关子查询那样,一次将子查询求解出来,然后求解父查询。  

内层查询由于与外层查询有关,因此必须反复求值。      

弄清相关子查询处理过程:    

从概念上讲,相关查询的一般处理过程是:    首先去外层查询中表的第1个元组,根据它与内层查询相关的属性值处理内层查询,    若WHERE子句返回值为真,则取此元组放入结果表;然后再取表的下一个元组;    重复这个过程直到外层表全部检查完为止。

注:类似与双层for 循环?

for (a : b) { 
for (c : d) {
if (a==c) {
returna;
        }
    }
}
select a.ENAMEfrom  scott.emp a
where exists(select*from  scott.dept b where b.deptno=a.deptno);

外部表的字段,和内部表的字段进行 比较相当于以下sql:

select a.ENAME from scott.emp a  where a.deptno in (select b.deptno from scott.dept b );

exists子查询实际是通过关联别的表安某种条件缩小主查询的范围。not exists  简单的理解就是 not exists= not in   实际not exists 取得是不属于exists限制条件的主表的数据集

目录
相关文章
|
24天前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
78 11
|
2月前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
2月前
|
存储 Oracle 关系型数据库
oracle数据恢复—Oracle数据库文件大小变为0kb的数据恢复案例
存储掉盘超过上限,lun无法识别。管理员重组存储的位图信息并导出lun,发现linux操作系统上部署的oracle数据库中有上百个数据文件的大小变为0kb。数据库的大小缩水了80%以上。 取出&并分析oracle数据库的控制文件。重组存储位图信息,重新导出控制文件中记录的数据文件,发现这些文件的大小依然为0kb。
|
29天前
|
存储 Oracle 关系型数据库
服务器数据恢复—华为S5300存储Oracle数据库恢复案例
服务器存储数据恢复环境: 华为S5300存储中有12块FC硬盘,其中11块硬盘作为数据盘组建了一组RAID5阵列,剩下的1块硬盘作为热备盘使用。基于RAID的LUN分配给linux操作系统使用,存放的数据主要是Oracle数据库。 服务器存储故障: RAID5阵列中1块硬盘出现故障离线,热备盘自动激活开始同步数据,在同步数据的过程中又一块硬盘离线,RAID5阵列瘫痪,上层LUN无法使用。
|
2月前
|
SQL Oracle 关系型数据库
Oracle数据库优化方法
【10月更文挑战第25天】Oracle数据库优化方法
57 7
|
2月前
|
Oracle 关系型数据库 数据库
oracle数据库技巧
【10月更文挑战第25天】oracle数据库技巧
35 6
|
2月前
|
存储 Oracle 关系型数据库
Oracle数据库优化策略
【10月更文挑战第25天】Oracle数据库优化策略
36 5
|
Oracle 关系型数据库 索引
Oracle 五种表的优缺点总结
Oracle 五种表的优缺点总结  从理论上来看,根本就不存在一种能够满足所有读取要求的数据存储方式   表的设计成就英雄,没有最高的技术只有最合适的技术。
1138 0
|
3月前
|
存储 Oracle 关系型数据库
Oracle数据库的应用场景有哪些?
【10月更文挑战第15天】Oracle数据库的应用场景有哪些?
218 64
|
3月前
|
存储 Oracle 关系型数据库
数据库数据恢复—Oracle ASM磁盘组故障数据恢复案例
Oracle数据库数据恢复环境&故障: Oracle ASM磁盘组由4块磁盘组成。Oracle ASM磁盘组掉线 ,ASM实例不能mount。 Oracle数据库故障分析&恢复方案: 数据库数据恢复工程师对组成ASM磁盘组的磁盘进行分析。对ASM元数据进行分析发现ASM存储元数据损坏,导致磁盘组无法挂载。

推荐镜像

更多