zoukankan      html  css  js  c++  java
  • 关于mysql的初步学习 (四)

     继续深入学习下 group by的使用:

      它的语法是

        select

                column_name1,column_name2,。。。,function(column_name)

         from

                table_name

         where

                column_name operator valuue

        group by

               column_name1,column_name2,。。。

       

       比如说:求一个班上的男女各多少人,并且有哪些人,上面的就都用得着:

        select 性别,group_concat(人名),count(人名) from 表 group by sex;

        如下图所示一样:

         select count(*),CarTypeID,group_concat(LicencePlate)from carinfotb_common  group by CarTypeID;

                       

         我是这么想的:

      1、Group by按照某一个column_name分组 ,那么 查询的列就肯定会包含这个column_name,function函数可以是某一个column_name 也可以是 “*”。但是要注意区别:

                                      count(*)对行的数目进行计算,包含NULL
                                      count(column)对特定的列的值具有的行数进行计算,不包含NULL值。
                                      count()还有一种使用方式,count(1)这个用法和count(*)的结果是一样的。

       2、 函数可以包含 count,sum,avg等这些数值运算。

                                         

       3、也可使用group_concat(column_name,。。。)函数,他可以把你分组里面所查的column_name值以‘,’连接起来,得到一个字符串。

       4、也可以使用order by 进行排序。

    select count(*),CarTypeID,group_concat(LicencePlate)from carinfotb_common group by CarTypeID ORDER BY COUNT(*) DESC;

           

       5、也可以使用 where 和having查询筛选数据

                      select count(*),CarTypeID,group_concat(LicencePlate)from carinfotb_common WHERE CarTypeID !='' group by CarTypeID ORDER BY COUNT(*) DESC;

    • where 子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,where条件中不能包含聚组函数,使用where条件过滤出特定的行。
    • having 子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having 条件过滤出特定的组,也可以使用多个分组标准进行分组。

                   select count(*),CarTypeID,group_concat(LicencePlate)from carinfotb_common WHERE CarTypeID !='' group by CarTypeID having count(*) > 10 ORDER BY COUNT(*) DESC;

       6、group by 可以是多个column_name 。那分组的条件是多个column_name之间的彼此联系。

     关键是搞起需求的意图,弄清楚分组的列,运用好函数。  参考文章:http://blog.csdn.net/xxpyeippx/article/details/8059910写的更详细。运用了多个列分组。 

    详细的数据查询结果不是很清晰

  • 相关阅读:
    Spring Boot启动命令参数详解及源码分析
    面试题-关于Java线程池一篇文章就够了
    Spring Boot中@ConditionalOnProperty使用详解
    Spring Boot通过ImportBeanDefinitionRegistrar动态注入Bean
    Spring Boot 注解之ObjectProvider源码追踪
    软件从业者不可不读的一本书
    SpringBoot之DispatcherServlet详解及源码解析
    书终于交稿了,聊聊写技术书这件事
    Python IDE:pycharm
    python安装
  • 原文地址:https://www.cnblogs.com/doui/p/6775254.html
Copyright © 2011-2022 走看看