SQL 中union的使用

本文探讨了如何通过WHERE子句和UNION操作符进行SQL查询,比较了两者在筛选大面积和高人口数据时的效率,并强调了UNION的规则和适用场景,特别是关于去重和列类型兼容性的注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述
采用where的解法

select
name,population,area
from World
where
area>3000000
or 
population>25000000
;

使用union的解法

select
name,population,area
from World
where
area>3000000
union
select
name,population,area
from World
where
population>25000000
;

使用 union 的速度比where要快
使用union的注意规则:
1.UNION必须由两条以上的SELECT语句组成,语句之间用关键字UNION分割。
2.UNION中的每个查询必须包含相同的列、表达式或聚集函数(各个列不需要以相同的次序列出)。
3.列数据类型必须兼容:类型不必完全相同,但必须是DBMS可以隐含地转换的类型。
4.如果取出来的数据不需要去重,使用UNION ALL。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值