本章主要讲授如何使用union操作符将多条select语句组合成一个结果集。
17.1 组合查询
组合查询的使用情况:
- 在单个查询中从不同的表返回类似结构的数据
- 对单个表执行多个查询,按多个查询返回数据
17.2 使用union
使用union是很简单的,只要在多条select语句中间加上union即可。
select vend_id, prod_id, prod_price
from products
where prod_price <= 5
union
select vend_id, prod_id, prod_price
from products
where vend_id in (1001,1002);
17.3 使用union的规则
使用union时请注意以下规则:
- union必须由两条或者两条以上的select语句组成,语句之间用关键词union隔开
- union的每个查询必须包含相同的列,表达式或者聚集函数
- 列数据的数据类型必须要兼容(不需要完全相同,但是必须要是dbms能够隐式转换的)
17.4 包含或者取消重复行
union默认的行为是不包含重复行,如果你想要包含重复行,请使用union all关键词。union all的这个特性使得其与where子句不同。
17.5 对组合查询的结果进行排序
只能使用一条order by语句,放在最后一条select语句的最后即可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类