SQL 子查询

由SAS adv 63题中
Given the SAS data sets:
WORK.EMPLOYEE WORK.NEWEMPLOYEE
Name Dept Names Salary
Alan Sales Michelle 50000
Michelle Sales Paresh 60000
A SAS program is submitted and the following is written to the SAS log:

101 proc sql;
 102 select dept, name
 103 from WORK.EMPLOYEE
 104 where name=(select names
 from newemployee
 where salary > 40000)

ERROR: Subquery evaluated to more than one row.
105 ;
106 quit;
What would allow the program to successfully execute without errors?

A. Replace the where clause with: 
where EMPLOYEE.Name=(select Names delimited with‘,'
 from WORK.NEWEMPLOYEE
 where Salary > 40000);
B. Replace line 104 with:
where EMPLOYEE.Name =ANY (select Names separated with‘,'
 from WORK.NEWEMPLOYEE
 where Salary > 40000);

where型子查询:指把内部查询的结果作为外层查询的比较条件。
from型子查询:把内层的查询结果当成临时表,供外层sql再次查询。
in子查询:内层查询语句仅返回一个数据列,这个数据列的值将供外层查询语句进行比较。
exists子查询:把外层的查询结果,拿到内层,看内层是否成立,简单来说后面的返回true,外层(也就是前面的语句)才会执行,否则不执行。
any/some子查询:只要满足内层子查询中的任意一个比较条件,就返回一个结果作为外层查询条件。
all子查询:内层子查询返回的结果需同时满足所有内层查询条件。
  比较运算符子查询:子查询中可以使用的比较运算符如 “>” “<” “= ” “!=”

作者:机智的豆子
来源:优快云
原文:https://blog.youkuaiyun.com/qq_39380737/article/details/81127497
版权声明:本文为博主原创文章,转载请附上博文链接!
正确样例

proc sql;
select *
from datalib.dm
where Subject_Id=any(select Subject_Id
from datalib.ds
where dsyn<'是') ;
quit;

替换

where Subject_Id in(select Subject_Id

where Subject_Id=some(select Subject_Id

where exists(select *
              from datalib.ds
             where dm.Subject_Id=ds.Subject_Id and dsyn<'是') ;

union 纵表连接 表现得不如set
set 中 两表纵表连接

data c;
set a b;

就直接 b接在a后面

    data c;
    set a b;
    by x y;

有by 就是a b 必须先按照 x y 排序
这样pdv读入之前就会对两个数据集中的数据先按照 x y进行比较

http://www.runoob.com/sql/sql-union.html

### SQL 子查询使用指南与示例 SQL 子查询是指在一个 SQL 查询语句中嵌套另一个查询语句。子查询可以出现在 `SELECT`、`INSERT`、`UPDATE` 或 `DELETE` 语句中,通常用于提供动态数据或条件过滤。以下是一些常见的子查询用法及其示例。 #### 1. 基本子查询 基本子查询通常用于从表中检索单一值,并将其作为主查询的条件。 ```sql SELECT ename, sal FROM emp WHERE sal > (SELECT AVG(sal) FROM emp); ``` 上述查询返回所有薪资高于平均薪资的员工姓名和薪资[^1]。 #### 2. 相关子查询 相关子查询是指子查询依赖于外部查询中的列,每次执行外部查询时,子查询都会重新计算。 ```sql SELECT e.* FROM employees e WHERE salary > (SELECT AVG(salary) FROM employees WHERE dept_id = e.dept_id); ``` 此查询返回每个部门中薪资高于该部门平均薪资的员工信息[^2]。 #### 3. 内联视图子查询 内联视图子查询是将子查询的结果集作为虚拟表使用,通常用于排序或限制结果行数。 ```sql -- 获取按薪资排序的所有员工 SELECT ename, job, sal, rownum FROM (SELECT ename, job, sal FROM emp ORDER BY sal); -- 获取薪资最低的前5名员工 SELECT ename, job, sal, rownum FROM (SELECT ename, job, sal FROM emp ORDER BY sal) WHERE rownum <= 5; ``` 这些查询展示了如何通过子查询对结果进行排序和限制[^4]。 #### 4. 在 `HAVING` 子句中使用子查询 在聚合函数中使用子查询可以帮助实现更复杂的过滤条件。 ```sql SELECT deptno, job, AVG(sal) FROM emp GROUP BY deptno, job HAVING AVG(sal) > (SELECT sal FROM emp WHERE ename = 'MARTIN'); ``` 此查询返回所有平均薪资高于员工 MARTIN 薪资的部门及其职位。 #### 5. 子查询优化技巧 对于相关子查询,由于每次外部查询都会重新计算子查询,因此性能可能较差。可以通过索引优化或改写为连接查询来提高效率[^3]。 ```sql -- 使用连接查询替代相关子查询 SELECT e1.* FROM employees e1 JOIN (SELECT dept_id, AVG(salary) AS avg_salary FROM employees GROUP BY dept_id) e2 ON e1.dept_id = e2.dept_id WHERE e1.salary > e2.avg_salary; ``` ### 注意事项 - 子查询必须包含在圆括号中。 - 子查询可以返回单个值、一行或多行,但需要根据上下文正确使用。 - 对于复杂查询,建议使用索引或优化查询逻辑以提高性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值