一、汇总统计

1、聚集函数

COUNT()      计算总数
SUM() 求和
MAX() 最大值
MIN() 最小值
AVG() 平均值

2、聚集函数使用

总共有多少名学生?
SELECT COUNT(*) FROM student; 所有学生的数学成绩总和?
SELECT SUM(score) FROM student; 所有学生的数学成绩最高分?
SELECT MAX(score) FROM student; 所有学生的数学成绩最低分?
SELECT MIN(score) FROM student; 所有学生的数学成绩平均分?
SELECT AVG(score) FROM student; ###
有多少名学生?
SELECT COUNT(*) FROM student; 219 另一种写法:
SELECT COUNT(score) FROM student; 219
SELECT COUNT(student_id) FROM student; 219
SELECT COUNT(1) FROM student; 219
SELECT COUNT('ABC') FROM student; 219
SELECT COUNT(teacher_id) FROM student; 205 COUNT(teacher_id) 忽略掉了值为null的行; 同样忽略值为NULL的行:
SELECT MAX(score) FROM student;
SELECT MIN(score) FROM student;
SELECT SUM(score) FROM student;
SELECT AVG(score) FROM student; count(*) 与count(1)比较:
如果你的数据表没有主键,那么count(1)比count(*)快
如果有主键的话,那主键(联合主键)作为count的条件也比count(*)要快
如果你的表只有一个字段的话那count(*)就是最快的啦
count(*) count(1) 两者比较。主要还是要count(1)所相对应的数据字段。
如果count(1)是聚索引,id,那肯定是count(1)快。但是差的很小的。
因为count(*),自动会优化指定到那一个字段。所以没必要去count(?),用count(*),sql会帮你完成优化的。 AVG(score) 等价于SUM(score)/COUNT(score)

3、分组汇总统计

关键字:GROUP BY

比如:
如何获取每个班级的数学成绩平均分(因为学生太多,这里先不计算成绩在80分以下的学生),以便比较不同班级的成绩? SELECT class_id,avg(score) FROM student WHERE score > 80 GROUP BY class_id; 注意:SELECT里除了使用聚集函数返回的字段外,其他所有的字段都必须原样出现在GROUP BY的后面;

比如:
如何统计不同的交易所的总的买入金额? SELECT left(stock_code,2),sum(price*volume)
FROM t_stock_trans_dtl
WHERE opt_typ = '买入'
GROUP BY left(stock_code,2); 比如:
如何统计不同的交易所的不同交易类型的总的交易金额?
#根据多个字段分组
SELECT left(stock_code,2),opt_typ,sum(price*volume)
FROM t_stock_trans_dtl
GROUP BY left(stock_code,2),opt_typ; GROUP BY会将NULL值的行,分到同一组计算统计值; SELECT teacher_id,count(*)
FROM student
GROUP BY teacher_id;

二、汇总统计

1、过滤分组结果

关键字:GROUP BY + HAVING
having关键字专门用来对group by进行指定条件; having和where比较:
having:过滤分组,在GROUP BY后执行;
where:过滤行,在GROUP BY前执行; 比如:
如何获取教授15名以上学名的老师? SELECT teacher_id,count(*)
FROM student
GROUP BY teacher_id
HAVING count(*) > 15; 比如:
如何获取数学成绩平均分在70分及以上的班级? SELECT
class_id,avg(score)
FROM student
GROUP BY class_id
HAVING avg(score) >= 70;

2、排序分组结果

比如:
如何获取每个班级的数学成绩平均分(不计算数学成绩在80分以下的学生),然后以平均分从高到低排序? 使用关键字:GROUP BY + ORDER BY #会先执行where,再进行order by
SELECT
class_id,avg(score)
FROM student
WHERE score > 80
GROUP BY class_id
ORDER BY avg(score) DESC; 如果每次查询都想得到确定的排序结果,则必须使用ORDER BY!

3、SELECT子句顺序

最简单的SQL语句:

SELECT 1;

SQL基础-汇总统计及GROUP BY的更多相关文章

  1. sql 基础练习 计算7天各个时间点的总和 group by order mysql一次查询多个表

    SQL 基础练习 -- 创建数据库 CREATE DATABASE school CHARACTER SET UTF8; -- 使用数据库 USE school; -- id: 学生的id -- na ...

  2. Oracle知识梳理(三)操作篇:SQL基础操作汇总

    Oracle知识梳理(三)操作篇:SQL基础操作汇总 一.表操作 1.表的创建(CREATE TABLE): 基本语句格式:       CREATE TABLE  table_name ( col_ ...

  3. SQL基础操作汇总

    SQL基础操作汇总 一.表操作 1.表的创建(CREATE TABLE): 基本语句格式:    CREATE TABLE  table_name ( col_name    datatype, -- ...

  4. SQL基础-----DML语句

    之前已经介绍过SQL基础之DDL(数据库定义语言)语句,http://www.cnblogs.com/cxq0017/p/6433938.html(这是地址) 这篇文章主要介绍DML语句(数据库操纵语 ...

  5. 2.Mysql SQL基础

    2.Mysql SQL基础2.1 SQL简介 SQL(Structure Query Language)是结构化查询语言.2.2 SQL使用入门 2.2.1 SQL分类 SQL分为DDL.DML(DQ ...

  6. c#Winform程序调用app.config文件配置数据库连接字符串 SQL Server文章目录 浅谈SQL Server中统计对于查询的影响 有关索引的DMV SQL Server中的执行引擎入门 【译】表变量和临时表的比较 对于表列数据类型选择的一点思考 SQL Server复制入门(一)----复制简介 操作系统中的进程与线程

    c#Winform程序调用app.config文件配置数据库连接字符串 你新建winform项目的时候,会有一个app.config的配置文件,写在里面的<connectionStrings n ...

  7. 《SQL基础教程》+ 《SQL进阶教程》 学习笔记

    写在前面:本文主要注重 SQL 的理论.主流覆盖的功能范围及其基本语法/用法.至于详细的 SQL 语法/用法,因为每家 DBMS 都有些许不同,我会在以后专门介绍某款DBMS(例如 PostgreSQ ...

  8. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  9. 黑马程序员+SQL基础(上)

    黑马程序员+SQL基础 ---------------<a href="http://edu.csdn.net"target="blank">ASP ...

随机推荐

  1. win10下更新anaconda和pip源

    第一步:更新anaconda源. anaconda的官方源太慢,推荐清华源:https://mirrors.tuna.tsinghua.edu.cn/help/anaconda/ 软件下载也可以在这个 ...

  2. 仅反射加载(ReflectionOnlyLoadFrom)的 .NET 程序集,如何反射获取它的 Attribute 元数据呢?

    原文:仅反射加载(ReflectionOnlyLoadFrom)的 .NET 程序集,如何反射获取它的 Attribute 元数据呢? 平时我们获取一个程序集或者类型的 Attribute 是非常轻松 ...

  3. java之spring之对象的创建

    首先提供目录结构如下: 下面提供各文件代码,以供参考: UserDynamicFactory.java package cn.sxt.factory; import cn.sxt.vo.User; / ...

  4. Object类的toString()和equals()方法

    我们知道,Object类是所有类的父类,因此也被称为根类.祖先.那么,我们就来看一看Object类的最常用的两个方法是如何用的. 1.toString方法: Object类的toString()方法默 ...

  5. 2019 58同城java面试笔试题 (含面试题解析)

    本人3年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.58同城等公司offer,岗位是Java后端开发,最终选择去了58同城. 面试了很多家公司,感觉大部分公司考察的点 ...

  6. Softmax学习笔记

    softmax用于多分类过程中,它将多个神经元的输出,映射到(0,1)区间内,可以看成概率来理解,从而来进行多分类! 他把一些输入映射为0-1之间的实数,并且归一化保证和为1,因此多分类的概率之和也刚 ...

  7. Javascript处理数组的方法

    一 迭代方法 ES5为数组定义了5个迭代方法,这些方法大大方便了处理数组的任务,支持这些方法的浏览器有 IE9+,Firefox2+,Safari3+,Opera9.5+和Chrome. 1 ever ...

  8. 采用__call__ 实现装饰器模式

    装饰器模式在实现中也是很常见的:比如手机贴膜,手机壳 都是为了给手机增加一些额外功能 增加耐操 装饰器模式的本质就是对对象二次包装,赋额外功能 __call__ __call__是python魔术方法 ...

  9. echarts自动播放图形

    echarts中要做到自动播放的功能,首先是要实现能缩放的功能,而缩放的功能是由配置项dataZoom来控制的,而dataZoom中分为inside和slider,分别是内置的控制器和外部的控制器,内 ...

  10. 基于web站点的xss攻击

    XSS(Cross Site Script),全称跨站脚本攻击,为了与 CSS(Cascading Style Sheet) 有所区别,所以在安全领域称为 XSS. XSS 攻击,通常指黑客通过 HT ...