`
weitao1026
  • 浏览: 1048271 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论
阅读更多

对某个表进行count  排序 显示字段 在group by 显示的字段  不显示的太多字段 不然有重复的

聚合函数

    在介绍GROUP BY 和 HAVING 子句前,我们必需先讲讲sql语言中一种特殊的函数:聚合函数, 例如SUM, COUNT, MAX, AVG等。这些函数和其它函数的根本区别就是它们一般作用在多条记录上。

SELECT SUM(population) FROM bbc

这里的SUM作用在所有返回记录的population字段上,结果就是该查询只返回一个结果,即国家的总人口数。

GROUP BY用法

    Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”。它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若干个小区域进行数据处理。
注意:group by 是先排序后分组;
    举例子说明:如果要用到group by 一般用到的就是“每这个字段” 例如说明现在有一个这样的表:每个部门有多少人 就要用到分组的技术

select DepartmentID as '部门名称',
COUNT(*) as '个数' from BasicDepartment group by DepartmentID
  • 1
  • 2
  • 1
  • 2

    这个就是使用了group by +字段进行了分组,其中我们就可以理解为我们按照了部门的名称ID,DepartmentID将数据集进行了分组;然后再进行各个组的统计数据分别有多少;
    通俗一点说:group by 字段1,字段2。。。(整个表中不止这两个字段)表示数据集中字段1相等,字段2也相等的数据归为一组,只显示一条数据。那么你可以对字段3进行统计(求和,求平均值等)

注意
select DepartmentID,DepartmentName from BasicDepartment group by DepartmentID

–将会出现错误

    选择列表中的列 ‘DepartmentName’ 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。这就是我们需要注意的一点,如果在返回集字段中,这些字段要么就要包含在Group By语句的后面,作为分组的依据;要么就要被包含在聚合函数中。为什么呢,根据前面的说明:DepartmentID相等的数据归为一组,只显示一条记录,那如果数据集中有这样三条数据。

      DepartmentID                              DepartmentName
            dept001                                            技术部
            dept001                                            综合部
            dept001                                            人力部
那我只能显示一条记录,我显示哪个?没法判断了。到这里有三种选择:

  1. 把DepartmentName也加入到分组的条件里去(GROUP BY DepartmentID,DepartmentName),那这三条记录就是三个分组。
  2. 不显示DepartmentName字段。
  3. 用聚合函数把这三条记录整合成一条记录count(DepartmentName)

WHERE和 HAVING

    HAVING子句可以让我们筛选成组后的各组数据。HAVING子句可以使用聚合函数
    WHERE子句在聚合前先筛选记录.也就是说作用在GROUP BY 子句和HAVING子句前. WHERE字句中不能使用聚合函数
    举例说明:
    一、显示每个地区的总人口数和总面积.

SELECT region, SUM(population), SUM(area)
FROM bbc
GROUP BY region
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

    先以region把返回记录分成多个组,这就是GROUP BY的字面含义。分完组后,然后用聚合函数对每组中的不同字段(一或多条记录)作运算。

    二、 显示每个地区的总人口数和总面积.仅显示那些面积超过1000000的地区。

SELECT region, SUM(population), SUM(area)
FROM bbc8 F4 w2 v( P- f
GROUP BY region
HAVING SUM(area)>1000000
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

    在这里,我们不能用where来筛选超过1000000的地区,因为表中不存在这样一条记录。相反,HAVING子句可以让我们筛选成组后的各组数据

    需要注意说明:当同时含有where子句、group by 子句 、having子句及聚集函数时,执行顺序如下:
    执行where子句查找符合条件的数据;
    使用group by 子句对数据进行分组;对group by 子句形成的组运行聚集函数计算每一组的值;最后用having 子句去掉不符合条件的组。
    having子句和where子句都可以用来设定限制条件以使查询结果满足一定的条件限制。
    having子句限制的是组,而不是行。where子句中不能使用聚集函数,而having子句中可以。

GROUP BY 与COUNT的一些复杂用法

直接用例子来说明吧
现有表:居民区表:DW_DM_RE_RC,部分字段如下

select AREA_ID,AREA_NAME,CITY_ID,CITY_NAME,RC_ID,RC_NAME,RC_TYPE_ID,RC_TYPE_NAME,RC_ADDRESS,FLOOR_CNT,BUILDING_CNT from DW_DM_RE_RC
  • 1
  • 1

这里写图片描述
数据主要集中在宿迁和无锡两个地市。
现需要根据AREA_ID和CITY_NAME进行分组,且显示同一个AREA_ID的数据数量。(AREA_ID和AREA_NAME相关联,CITY_ID,CITY_NAME相关联)
第一步:
sql1:

select COUNT(*) as COUNT,AREA_ID,AREA_NAME,CITY_ID,CITY_NAME from DW_DM_RE_RC
group by AREA_ID,AREA_NAME,CITY_ID,CITY_NAME
  • 1
  • 2
  • 1
  • 2

这里写图片描述
这里COUNT显示的是以AREA_ID和CITY_NAME为条件进行分组的,
表示AREA_ID=510,CITY_NAME=’滨湖区’(无锡市滨湖区)的数据有131条,表示AREA_ID=510,CITY_NAME=’宜兴’(无锡市宜兴区)的数据有131条,表示AREA_ID=527,CITY_NAME=’泗洪’(宿迁市泗洪区)的数据有101条,但我需要的是属于AREA_ID=510(无锡市,不管哪个区)的总数据量有多少,并且需要显示CITY_NAME。也就是需要改变显示的COUNT值。由此得到启发
sql2:

SELECT T1.AREA_ID,T1.AREA_NAME,T1.CITY_ID,T1.CITY_NAME,T2.COUNT FROM 
(SELECT COUNT(*) AS COUNT,AREA_ID,AREA_NAME,CITY_ID,CITY_NAME FROM DW_DM_RE_RC
GROUP BY AREA_ID,AREA_NAME,CITY_ID,CITY_NAME) T1
LEFT JOIN ( 
    SELECT COUNT(*) AS COUNT,AREA_ID,AREA_NAME FROM DW_DM_RE_RC
    GROUP BY AREA_ID,AREA_NAME
)T2 ON  T1.AREA_ID = T2.AREA_ID AND T1.AREA_NAME = T2.AREA_NAME
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

<!-- Baidu Button BEGIN -->

 

 <!-- Baidu Button END -->  

 

分享到:
评论

相关推荐

    group by的详解

    在Oracle数据库中,`GROUP BY`语句是用于将数据行根据一个或多个列的值进行分组,以便对每个组执行聚合函数(如`SUM`、`COUNT`、`AVG`等)。`GROUP BY`的主要作用在于将具有相同列值的数据归类到一起,从而可以对每...

    Linq Grouping GroupBy 用法详解

    本文将深入探讨`GroupBy`方法的使用,包括其基本用法、多键分组以及在实际开发中的应用示例。 ### 1. 基本用法 `GroupBy`方法接收一个函数作为参数,该函数用于从每个元素中提取分组键。例如,如果你有一个`...

    mysql中count(), group by, order by使用详解

    然而,当`COUNT()`与`ORDER BY`一起使用时,如果没有嵌套子查询,`ORDER BY`可能不会按预期工作,因为`COUNT()`可能会在排序之前执行,导致排序失效。 解决这个问题的一种方法是使用嵌套子查询,先对数据进行排序,...

    简单讲解sql语句中的group by的使用方法

    下面我们将详细讨论`GROUP BY`的使用方法及其相关知识点。 1. **`GROUP BY`的基本概念** `GROUP BY`关键字用于将数据表中的数据根据一个或多个列的值进行分组。通过分组,你可以对每个组应用聚合函数,这有助于...

    Group_by详解_完美例句

    最基础的`GROUP BY`用法是配合聚合函数(如`COUNT()`、`SUM()`、`AVG()`等)来统计每个组的汇总信息。例如,以下SQL语句将统计每个国家的水果种类数量: ```sql SELECT COUNT(*) AS 水果种类, ProductPlace AS 出产...

    SQL GROUP BY 语句详解

    在处理大型数据集时,GROUP BY 与聚合函数(如 SUM、COUNT、AVG、MAX 和 MIN)一起使用,能够帮助我们汇总数据,找出特定条件下的总体趋势和统计信息。 GROUP BY 语句的基本语法如下: ```sql SELECT column_name,...

    order_by_、group_by_、having的用法区别.doc

    ### SQL中的ORDER BY, GROUP BY, HAVING 的用法区别详解 #### 一、概述 在SQL查询语言中,`ORDER BY`, `GROUP BY`, 和 `HAVING` 是三个非常重要的概念,它们分别用于对查询结果进行排序、分组以及在分组后进一步...

    Oracle中分组查询group by用法规则详解

    `GROUP BY`是Oracle SQL中用于数据分组的关键语句,常与聚合函数、`HAVING`子句和`ORDER BY`子句一起使用,提供了一种强大方式来分析和汇总数据库中的大量数据。了解并熟练掌握这些用法对于进行复杂的数据分析至关...

    SQL问题详解之_having_Group by

    GROUP BY用于将数据分组,而HAVING则用于筛选这些分组,提供了一种在聚合数据级别应用条件的方法。这两个子句常与聚合函数一起使用,帮助我们从大量数据中提取出有价值的统计信息。 在实际的数据库查询中,GROUP BY...

    MYSQL GROUP BY用法详解

    在数据库管理和分析中,`GROUP BY`通常与聚合函数(如`COUNT`, `SUM`, `AVG`, `MAX`, `MIN`)一起使用,帮助我们从大量数据中获取有用的信息。 在本例中,`GROUP BY`被用来解决重复数据的问题。首先,创建了一个名...

    group by 语法大全,内附列子

    ### Group By 语法详解与应用实例 在数据库查询语言SQL中,`GROUP BY`语句是一种非常强大的工具,它能够帮助我们对数据进行分组处理,以便更好地进行数据分析和汇总。下面将详细介绍`GROUP BY`的基本语法、常用场景...

    详解SQL中Group By的使用教程

    本教程将深入讲解`GROUP BY`的使用方法。 1. **概述** `GROUP BY`的主要功能是将数据表中的数据按照指定的列进行分组,每个分组内的数据具有相同的列值。这通常与聚合函数(如`SUM`, `COUNT`, `AVG`, `MAX`, `MIN`...

    详解SQL中Group By的用法

    在SQL中,`GROUP BY`语句是数据分析和报表生成的核心工具之一,它允许我们根据一个或多个列的值对数据进行分组,并且通常与聚合函数一起使用,以对每个组进行计算。以下是关于`GROUP BY`用法的详细说明: 1. **基本...

    group by,having,order by的用法详解

    `GROUP BY` 用于将数据根据指定的一个或多个列进行分组,常与聚合函数(如`COUNT`,`SUM`,`AVG`,`MAX`,`MIN`)一起使用,以便对每个组进行统计计算。在使用`GROUP BY`时,如果查询中包含非分组列且未在聚合函数...

    详解partition by和group by对比

    首先,`GROUP BY` 是一个基础的分组函数,它根据指定的列将数据进行分组,并且通常与聚合函数如 `SUM`, `COUNT`, `AVG`, `MIN`, `MAX` 结合使用,用于对每个分组求和、计数或计算平均值等。`GROUP BY` 的作用是在 `...

    详解python中groupby函数通俗易懂

    本文将深入探讨`groupby()`函数的使用方法,帮助读者理解其核心概念,并通过实例来展示如何应用它进行数据处理。 1. **groupby()的基本功能** `groupby()`函数的主要作用是对DataFrame中的数据进行分组,并对每个...

Global site tag (gtag.js) - Google Analytics