group by 的用法

1  group by 是分组查询,一般group by是和聚合函数配合使用

group by 有一个原则,就是select 后面的列中,没有使用聚合函数(avg()  sum(),count() max(),min()---)的列,必须出现在group by 后面。

select  ename,count(empno),deptno from emp group by deptno,ename; 正确写法。

select ename,count(empno),deptno from emp group by deptno;  错误写法。//没有使用分组函数的列必须要出现在group by后面。

2  having

where 子句的作用是对查询结果进行分组前,将不符合where 条件的行去掉,即在分组之前过滤数据,条件中不能包含聚组函数,使用where条件显示特定的行。

having子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having条件显示特定的组,也可以使用多个分组标准进行分组。

having子句限制已经在select语句中定义的列和聚合表达式上。通常,你需要通过在having子句中重复聚合函数表达式来引用聚合值,就如你在select语句中做的那样。

例如:

select sal,ename,deptno from emp where ename like ‘m%‘  group by ename,sal,deptno having sal >100;

时间: 2024-10-13 07:50:04

group by 的用法的相关文章

SQL中group by的用法

group by即按照给定字段对结果集进行分组,从字面意义上理解就是根据"by"指定的规则对数据进行分组,所谓的分组就是将一个"数据集"划分成若干个"小区域",然后针对若干个"小区域"进行数据处理. group by的写法: 1.select 字段列表/* from 表名 group by 字段列表 2.select 字段列表/* from 表名 group by 字段列表 having 过滤条件 group by的特点: 常

mysql中count,GROUP BY的用法(转载)

计算你拥有动物的总数目与“在pet表中有多少行?”是同样的问题,因为每个宠物有一个记录.COUNT(*)函数计算行数,所以计算动物数目的查询应为: mysql> SELECT COUNT(*) FROM pet;+----------+| COUNT(*) |+----------+|        9 |+----------+在前面,你检索了拥有宠物的人的名字.如果你想要知道每个主人有多少宠物,你可以使用COUNT( )函数: mysql> SELECT owner, COUNT(*) F

总结 group by 的用法

今天用实例总结一下group by的用法. 归纳一下:group by:ALL ,Cube,RollUP,Compute,Compute by 创建数据脚本 Create Table SalesInfo(Ctiy nvarchar(50),OrderDate datetime,OrderID int) insert into  SalesInfoselect N'北京','2014-06-09',1001union allselect N'北京','2014-08-09',1002union a

mysql group by的用法 注意

group by 用法: 官方的解释:select 后面的字段必须出现在 group by 后面, 除非是聚合,sum,或者count 但是如果 是多表联查, SELECT    c.`name` AS NAME,    sum(b.uv) ASVALUE FROM    meta.dic_project_category a,    rpt_program_cat_people b,    meta.dic_app_category cWHERE    a.id = b.`name`AND a

mysql group by 的用法解析

1. group by的常规用法 group by的常规用法是配合聚合函数,利用分组信息进行统计,常见的是配合max等聚合函数筛选数据后分析,以及配合having进行筛选后过滤. 聚合函数max select max(user_id),grade from user_info group by grade ; 这条sql的含义很明确,将数据按照grade字段分组,查询每组最大的user_id以及当前组内容.注意,这里分组条件是grade,查询的非聚合条件也是grade.这里不产生冲突. havi

sql之group by的用法

1.概述 “Group By”从字面意义上理解就是根据“By”指定的规则对数据进行分组,所谓的分组就是将一个“数据集”划分成若干个“小区域”,然后针对若干个“小区域”进行数据处理. 2.原始表 3.简单Group By 示例1 select 类别, sum(数量) as 数量之和 from A group by 类别 返回结果如下表,实际上就是分类汇总. 4.Group By 和 Order By 示例2 select 类别, sum(数量) AS 数量之和 from A group by 类别

GROUP BY的用法

SELECT SUM(population) FROM bbc 这里的SUM作用在所有返回记录的population字段上,结果就是该查询只返回一个结果,即所有国家的总人口数. 显示每个地区的总人口数和总面积: SELECT region, SUM(population), SUM(area)FROM bbcGROUP BY region 先以region把返回记录分成多个组,这就是GROUP BY的字面含义.分完组后,然后用聚合函数对每组中的不同字段(一或多条记录)作运算 显示每个地区的总人口

sql中having与group by的用法

-------------自己测试--------------- select sname,sum(smon) from student group by sname having sum(smon)>7 ---------------自己测试----------------- 下面是正文 当同时含有where子句.group by 子句 .having子句及聚集函数时,执行顺序如下: 执行where子句查找符合条件的数据: 使用group by 子句对数据进行分组: 对group by 子句形

count group by 组合用法

1 需求是 求订单表1个月内 订单累计费用超过500的有多少人 根据题意 最先写出的sql是这样的 SELECT SUM(totalfee)AS n FROM sendorder WHERE `addtime` > UNIX_TIMESTAMP('2015-12-01') AND `addtime` < UNIX_TIMESTAMP('2016-01-01') AND state IN(1,2,3,8) GROUP BY uid HAVING n > 500 但是这样算出来的只是一个数组