一、GROUP BY

  GROUP BY语句用来与聚合函数(aggregate functions such as COUNT, SUM, AVG, MIN, or MAX.)联合使用来得到一个或多个列的结果集。语法如下:

SELECT column1,  ... column_n, aggregate_function(expression)
FROM tables
WHERE predicates
GROUP BY column1, ... column_n;

举例

  比如说我们有一个学生表格(student),包含学号(id),课程(course),分数(score)等等多个列,我们想通过查询得到每个学生选了几门课程,此时我们就可以联合使用COUNT函数与GROUP BY语句来得到这一结果

SELECT id, COUNT(course) as numcourse
FROM student
GROUP BY id

  因为我们是使用学号来进行分组的,这样COUNT函数就是在以学号分组的前提下来实现的,通过COUNT(course)就可以计算每一个学号对应的课程数。

注意

  因为聚合函数通过作用于一组数据而只返回一个单个值,因此,在SELECT语句中出现的元素要么为一个聚合函数的输入值,要么为GROUP BY语句的参数,否则会出错。例如,对于上面提到的表格,我们做一个这样的查询:

SELECT id, COUNT(course) as numcourse, score
FROM student
GROUP BY id

  此时查询便会出错,错误提示如下:

Column ‘student.score' is invalid in the select list because
it is not contained in either an aggregate function or the
GROUP BY clause.

  出现以上错误的原因是因为一个学生id对应多个分数,如果我们简单的在SELECT语句中写上score,则无法判断应该输出哪一个分数。如果想用score作为select语句的参数可以将它用作一个聚合函数的输入值,如下例,我们可以得到每个学生所选的课程门数以及每个学生的平均分数:

SELECT id, COUNT(course) as numcourse, AVG(score) as avgscore
FROM student
GROUP BY id

二、HAVING

  HAVING语句通常与GROUP BY语句联合使用,用来过滤由GROUP BY语句返回的记录集。HAVING语句的存在弥补了WHERE关键字不能与聚合函数联合使用的不足。语法:

SELECT column1, column2, ... column_n, aggregate_function (expression)
FROM tables
WHERE predicates
GROUP BY column1, column2, ... column_n
HAVING condition1 ... condition_n;

  同样使用本文中的学生表格,如果想查询平均分高于80分的学生记录可以这样写:

SELECT id, COUNT(course) as numcourse, AVG(score) as avgscore
FROM student
GROUP BY id
HAVING AVG(score)>=;

  在这里,如果用WHERE代替HAVING就会出错

最新文章

  1. Spark优化之二:集群上运行jar程序,状态一直Accepted且不停止不报错
  2. nodejs授权连接mongodb
  3. (转)ArcGIS制图技巧
  4. iOS修改手机定位(非越狱任意位置)
  5. Go Mobile 例子 basic 源码分析
  6. C#中Messagebox.Show()常用参数用法详解
  7. 在win10 64位下编译,提示[C++ Error] E2075 Incorrect project override option: (x86)\borland\cbuilder6\lib\vcl60.csm
  8. JS设置Cookie,及COOKIE的限制
  9. sqlserver2008用bat脚本备份时报错因为库名有中横杠【原创】
  10. centos 6.4 mysql rpm 离线安装【备忘】
  11. vue中计算属性computed方法内传参
  12. javax.el.PropertyNotFoundException: Property 'XXX' not found on type bean.XXXXX
  13. 7种方法实现移动端Retina屏幕1px边框效果
  14. 【转】PCB中3D相关功能详解
  15. TCP/IP 协议图--TCP/IP 基础
  16. pyhton 自动化pymysql操作mysqldb数据库增删改查封装
  17. nginx 用法
  18. 笔记-scrapy-signal
  19. phalcon中find 最常用
  20. C语言中可变参数的使用

热门文章

  1. Java变量和对象的作用域
  2. 【C++】浅谈三大特性之一继承(一)
  3. 【Electron】Electron开发入门(八):自定义electron框架外壳(shell)的菜单(Menu)
  4. as3中去掉字符串两边的空格,换行符
  5. poj 3270 Cow Sorting (置换入门)
  6. 新人小达之wpf
  7. laravel安装插件laravel-ide-helper
  8. css 实现旋转八卦图
  9. druid 连接kafuk
  10. Linux--管道pipe