SQL 嵌套查询 简记

嵌套查询:将一查询快嵌套在另一个查询块的WHERE子句或HAVING短句的条件中的嵌套查询。

SQL语言允许多层嵌套查询,即一个子查询中还可以嵌套其他子查询。子查询的SELECT语句不能使用ORDER BY子句(ORDER BY 子句只能对最终结果进行排序)。

(所有需要操作的表都在这里建立:https://blog.csdn.net/qq_44647223/article/details/110249062)

1.带谓词IN的嵌套查询

select mat_num, speci, amount
from stock
where warehouse IN
(	select warehouse
	from stock
	where speci='BVV-120' AND mat_name='护套绝缘电线'
);

在这里插入图片描述

2.带比较运算符的子查询

示例1:

select mat_num, speci, amount
from stock 
where warehouse=  /*查询的结果只有一个值,所以可以用 "=" 代替IN*/
(	select AVG(amount)
	from stock s2
	where speci='BVV-120' AND mat_name='护套绝缘电线'
);

在这里插入图片描述
示例2:

select mat_num, mat_name, speci, amount
from stock s1
where amount >
(	select AVG(amount)
	from stock s2
	where s2.warehouse = s1.warehouse
);

在这里插入图片描述

3.带有ANY或ALL谓词的子查询

比较运算符的语义
在这里插入图片描述

示例1:
查询比1#仓库的某一物资库存量少的记录

select mat_name, speci, amount
from stock
where warehouse <> '1#仓库'
	AND amount < ANY
		(	select amount
			from stock
			where warehouse='1#仓库'
		);

在这里插入图片描述

4.带有EXISTS谓语的子查询

EXISTS代表存在量词E。带有EXISTS谓词的子查询不返回任何数据,只产生逻辑真值TRUE或逻辑假值FALSE。

示例1:
查询使用m001号的工程项目

select prj_name
from test
where exists
(	select *
	from out_stock
	where prj_num=test.prj_num AND mat_num='m001'
);

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值