企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
多数sql查询只包含从一个或多个表中返回数据的单条select语句. 但是,sql也允许执行多个查询(多条select语句),并将结果作为一个查询结果集返回. 这些组合查询通常称为(union)或者复合查询 主要有两种情况需要使用组合查询 * 在一个查询中从不同的表返回结构数据 * 对一个表执行多个查询,按一个查询返回数据 **组合查询和多个where条件** 多数条件下,组合相同表的两个查询所完成的工作与具有多个where子句条件的一个查询所完成的工作相同,换句话说,任何具有多个where子句的select语句都可以作为一个组合查询 **创建组合查询** 可用union操作符来组合数条sql查询,利用union,可给出多条select语句,将他们的结果组合成一个结果集 **使用union** 使用union很简单,所要做的只是给出每条select语句,在各语句之间放上关键字union ![](https://box.kancloud.cn/5366dbfd9b05377f3c64e475148f021b_1076x400.png) **包含或取消重复的行** 注意在分别执行语句时,第一条select语句返回3行,第二条select语句返回2行.而在用union组合两条select语句后,只返回4行而不是5行 union从查询结果集中自动去除了重复的行,换句话说,它的行为与一条select语句中使用多个where子句条件一样.使用union时,重复的行会被自动取消 这是union的默认行为,如果愿意也可以改变他.事实上,如果想返回所有的匹配行,可使用union all而不是union **union与where** union几乎总是完成与多个where条件相同的工作.union all为union的一种形式,他完成where子句完成不了的工作. 如果确实需要每个条件的匹配行全部出现(包括重复行),就必须使用union all,而不是where **对组合查询排序** select语句的输出用order by子句排序.在用union组合查询时,只能使用一条order by子句,他必须位于最后一条select语句之后.对于结果集,不存在用一种方式排序一部分,而又用另一种方式排序另一部分的情况,因此不允许使用多条order by子句