SQL查询:on、where、group by条件解析
需积分: 43 31 浏览量
更新于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查询至关重要。在实际应用中,它们常常结合使用,以满足各种复杂的数据检索需求。熟练掌握这些概念可以帮助优化查询性能,避免不必要的数据处理,并准确地获取所需信息。
2020-09-09 上传
2012-11-11 上传
2020-09-09 上传
2023-06-08 上传
2023-07-11 上传
2023-06-09 上传
2023-06-09 上传
2023-05-12 上传
2024-05-08 上传
2023-06-12 上传
GracialLiu
- 粉丝: 0
- 资源: 1
最新资源
- C语言数组操作:高度检查器编程实践
- 基于Swift开发的嘉定单车LBS iOS应用项目解析
- 钗头凤声乐表演的二度创作分析报告
- 分布式数据库特训营全套教程资料
- JavaScript开发者Robert Bindar的博客平台
- MATLAB投影寻踪代码教程及文件解压缩指南
- HTML5拖放实现的RPSLS游戏教程
- HT://Dig引擎接口,Ampoliros开源模块应用
- 全面探测服务器性能与PHP环境的iprober PHP探针v0.024
- 新版提醒应用v2:基于MongoDB的数据存储
- 《我的世界》东方大陆1.12.2材质包深度体验
- Hypercore Promisifier: JavaScript中的回调转换为Promise包装器
- 探索开源项目Artifice:Slyme脚本与技巧游戏
- Matlab机器人学习代码解析与笔记分享
- 查尔默斯大学计算物理作业HP2解析
- GitHub问题管理新工具:GIRA-crx插件介绍