博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL学习之组合查询(UNION)
阅读量:6356 次
发布时间:2019-06-23

本文共 1420 字,大约阅读时间需要 4 分钟。

  hot3.png

1、大多数的SQL查询只包含从一个或多个表中返回数据的单条SELECT语句,但是,SQL也允许执行多个查询(多条SELECT语句),并将结果作为一个查询结果集返回。这些组合查询通常称为并或复合查询。

主要有两种情况需要使用组合查询:

(1)在一个查询中从不同的表返回结构数据

(2)对一个执行多个查询,按一个查询返回数据

 

2、使用UNION

使用UNION很简单,所要做的只是给出每条SELECT语句,然后再每条SELECT语句之间加上UNION关键字,这样所给出的SELECT结果集就能组合成一个结果集并返回。代码如下:

select * from dbo.Customers_1

e9c5855a92b6183572fe9af7701d5c54d24.jpg

现在有个需求,需要检索出位于浙江和上海,或者顾客名称为Fun4All的所有顾客,下面是通过WhERE子句完成的解决代码:

select * from dbo.Customers_1 where Province in('浙江','上海') or Company='Fun4All'

2d90cfe5643e886a7a530b35548c8048f90.jpg

ok,通过Where子句的OR操作符完成需求!

 

下面通过组合查询UNION操作符来完成需求,代码如下:

select * from dbo.Customers_1 where Province in('浙江','上海')select * from dbo.Customers_1 where Company='Fun4All'

bee85b221cfebc8305fdae613bdce3ab9ae.jpg

这是没有使用UNION的单独查询,一共有6条记录,如果是普通的结果集组合的话会出现6条记录,我们发现其中有两条记录是重复的4de6527a0c4a4d35ee6bc0cba94d24a2d0c.jpg

在看使用了UNION组合查询关键字的查询解决代码:

select * from dbo.Customers_1 where Province in('浙江','上海')UNION select * from dbo.Customers_1 where Company='Fun4All'

ba5ceef7d37bb1e6a31988e78ea3157368c.jpg

ok,完成需求,通过和上面没有使用UNION关键的分开查询相比,我们发现UNION(组合查询)从结果集中去除了重复的行。

这里我们可以使用UNION ALL,告诉DBMS不取消重复的行。那么效果就和上面没加UNION的一样

3、总结

分析上面完成需求的连个例子,我们发现对于上面的简单的例子使用UNION似乎比WHERE子句更加的复杂。但是这里你需要知道,如果对于较复杂的过滤条件,或者从多个表(而不是一个表)中检索数据的情形,使用UNION可能会使处理更加的简单。

 

4、使用UNION必须知道的规则(使用注意事项)

(1)使用UNION必须有两条或者两条以上的SELECT语句组成,语句之间用UNION关键字分割

(2)使用UNION关联的每个子查询必须包含相同的检索列、表达式或这聚集函数(次序可以不一样)

(3)列数据类型必须兼容;类型不必完全相同,但必须是DBMS可以隐含转换的类型(不同的数值类型或者不同的日期类型)

(4)UNION几乎总是完成与多个WHERE条件相同的工作,UNION ALL是UNION的一种形式,它完成WHERE子句完成不了的工作,因为他将返回每个条件的匹配行(包括重复行)

(5)使用组合查询,当需要对结果进行排序是,只能指定一条Order By语句,这条语句只能放在最后一天SELECT语句的后面.

 

转自:

转载于:https://my.oschina.net/8824/blog/2999756

你可能感兴趣的文章
谷歌Pixel 3吸引三星用户, 但未动摇iPhone地位
查看>>
VUE中使用vuex,cookie,全局变量(少代码示例)
查看>>
grep -w 的解析_学习笔记
查看>>
TX Text Control文字处理教程(3)打印操作
查看>>
CENTOS 7 如何修改IP地址为静态!
查看>>
MyCat分片算法学习(纯转)
查看>>
IO Foundation 3 -文件解析器 FileParser
查看>>
linux学习经验之谈
查看>>
mysqld_multi实现多主一从复制
查看>>
中介模式
查看>>
JS中将变量转为字符串
查看>>
servlet笔记
查看>>
JVM(五)垃圾回收器的前世今生
查看>>
Spring Boot 自动配置之@EnableAutoConfiguration
查看>>
web前端笔记
查看>>
finally知识讲解
查看>>
Matplotlib绘图与可视化
查看>>
openstack ocata版(脚本)控制节点安装
查看>>
【微信公众号开发】获取并保存access_token、jsapi_ticket票据(可用于微信分享、语音识别等等)...
查看>>
datatable 获取最大值
查看>>