SQL查询:on、where、group by条件解析
需积分: 43 175 浏览量
更新于2024-09-10
收藏 82KB DOC 举报
"SQL中on,where,group by的用法心得"
在SQL查询中,`on`、`where`和`group by`是三个非常重要的关键字,它们分别用于不同的查询场景,帮助我们从数据库中获取所需的数据。
1. **on** 条件
`on` 关键字主要用于在联接(join)操作中定义两个或多个表之间的关系。当执行`inner join`、`left join`、`right join`或`full outer join`时,`on`后面的条件决定哪些行会被匹配并合并。例如,在`left join`中,`on`条件确定的是临时表的生成,即使条件不满足,左表的所有记录也会被包含进来。例如:
```sql
select a.*, b.*
from tablea a
left join tableb b
on a.id = b.id and a.type = 1;
```
在这个例子中,`on a.id = b.id`定义了两个表之间的连接条件,而`a.type = 1`只会影响最终的结果集,因为它是在临时表生成后对数据进行筛选。
2. **where** 条件
`where` 关键字用于在查询中过滤行。它通常跟在`from`子句之后,用来指定满足特定条件的行。`where`条件可以用于所有类型的查询,包括单表查询和联接查询。在联接查询中,`where`一般用于进一步过滤临时表生成后的结果。例如:
```sql
select a.*, b.*
from tablea a
left join tableb b
on a.id = b.id
where a.type = 1;
```
这里的`where a.type = 1`会从已经联接好的临时表中去除那些`a.type`不等于1的行。
3. **group by** 子句
`group by` 用于将结果集按照一个或多个列进行分组,通常与聚合函数(如`count()`、`sum()`、`avg()`等)一起使用,以便计算每个组的统计信息。例如:
```sql
select a.type, count(b.id)
from tablea a
left join tableb b
on a.id = b.id
group by a.type;
```
这个查询会返回每种`a.type`的`b.id`数量,将数据按`a.type`分组并计数。
4. **having** 条件
类似于`where`,`having`也是用于过滤结果的,但它是针对已经分组的数据进行过滤的。`where`不能与聚合函数一起使用,而`having`可以。例如:
```sql
select a.type, count(b.id)
from tablea a
left join tableb b
on a.id = b.id
group by a.type
having count(b.id) > 10;
```
这个查询返回那些在`b.id`上有超过10个匹配项的`a.type`。
理解这三个关键字的区别和用法对于编写复杂的SQL查询至关重要。在实际应用中,它们常常结合使用,以满足各种复杂的数据检索需求。熟练掌握这些概念可以帮助优化查询性能,避免不必要的数据处理,并准确地获取所需信息。
1411 浏览量
2436 浏览量
114 浏览量
157 浏览量
124 浏览量
5634 浏览量
1992 浏览量
点击了解资源详情
115 浏览量
GracialLiu
- 粉丝: 0
- 资源: 1
最新资源
- 详细解析Java中抽象类和接口的区别
- ActionScript 3.0 Cookbook 中文完整版
- dwg文件说明文档(英文)
- c语言函数大全.pdf
- FLASH四宝贝之-使用ActionScript 3.0组件
- spring电子文档(官方)
- jstl电子文档。很有参考价值,我也找了很久跟大家分享
- JaVa课卷_ATM
- Linux初学者入门优秀教程
- ActionScript 3.0 Cookbook 中文完整版
- 中科大罗老师endnote讲义
- JavaMail 帮助 文档 pdf
- php5面向对象初步pdf格式
- 初学者必备 c语言实例50
- 让你不再害怕指针,详解指针的使用
- 嵌入式linux系统的设计与开发