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限制条件的主表的数据集