博客
关于我
mysql之分组查询GROUP BY,HAVING
阅读量:789 次
发布时间:2023-02-11

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

一、查询格式

在编写SQL查询时,需要遵循明确的语法结构。查询列表需要包含以下关键要素:

1. **选择列和函数**:使用`select`语句指定要查询的字段和聚合函数。例如,`select column, group_function(column)`。 2. **指定表名**:明确要操作的数据库表。例如,`from table_name`。 3. **筛选条件**:在`where`子句中添加条件筛选数据。注意:`where`子句后面不能使用`group by`或`having`后的字段别名。 4. **分组操作**:在`group by`子句中指定分组依据字段。例如,`group by field`。 5. **排序子句**:在`order by`子句中定义排序规则。例如,`order by column DESC`。

需要注意的是,查询列表比较特殊,`group by`和`having`后面的字段可以使用原语句前部分定义的别名,而`where`子句后面不能使用别名。

二、分组查询的案例

在实际操作中,需要注意分组查询的逻辑顺序。对于带筛选条件的分组查询,通常分为两种类型:

1. **分组前筛选**:通过原始表数据对记录进行筛选。这种方法可以直接放在`where`子句中。 2. **分组后筛选**:筛选条件依赖于`group by`后的聚合函数结果。这种情况下,筛选条件只能放在`having`子句中。

编写分组查询时,可以按照以下步骤进行:

1. 先写出`select`、`from`、`group by`的基本框架。 2. 观察筛选条件是否可以通过`where`子句完成。如果可以,直接在`where`中添加;如果不行,则需要将其放在`having`子句中。 3. 如果筛选条件涉及聚合函数的结果,则一定要放在`having`子句中。 4. 尽量先使用`where`子句进行筛选,减少`having`子句的使用,以提高查询性能。

**示例:简单的分组查询**

假设有以下数据表`user_info`,字段包括`id`、`username`、`email`、`role`。我们需要计算不同角色的用户数量及其平均邮箱数量。以下是查询步骤:

1. 写出基本框架: ```sql select role, count(id) as user_count, avg(email) as avg_email from user_info group by role having count(id) > 1 order by user_count desc ``` 2. 分析筛选条件:`having count(id) > 1`用于筛选每个角色下用户数量大于1的记录。这里的筛选条件依赖于`group by`后的`count(id)`,因此必须放在`having`子句中。 3. 执行查询,结果会显示不同角色的用户数量及对应的平均邮箱数量,并按用户数量排序。

转载地址:http://ixbfk.baihongyu.com/

你可能感兴趣的文章
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>
Mysql8.0以上重置初始密码的方法
查看>>
mysql8.0新特性-自增变量的持久化
查看>>