聚合查询

通过SQL对数据进行某种操作或计算时需要使用函数(聚合函数,将多行汇为一行)。

常用函数(5个):
  • COUNT:计算表中的记录数(行数)
  • SUM: 计算表中数值列中数据的合计值
  • AVG: 计算表中数值列中数据的平均值
  • MAX: 计算表中数值列中数据的最大值
  • MIN: 计算表中数值列中数据的最小值
COUNT()函数
-- 1.计算全部行数:
SELECT COUNT(*) FROM Product;
-- 2.计算null之外的数据的行数(将对象列设为参数):
SELECT COUNT(purchase_price) FROM Product;
-- 3.将包含null的列作为参数时,count(*)和count(<列名>)的结果不一样
SELECT COUNT(*), COUNT(purchase_price) FROM Product;
SUM:计算合计值
-- 1.计算单列合计值
SELECT SUM(sale_price) FROM Product;
-- 2.计算多列合计值
SELECT SUM(sale_price), SUM(purchase_price) FROM Product;
AVG:计算平均值
-- 1.计算某列平均值(如果该列存在null,则会被删除后再计算)
SELECT AVG(sale_price) FROM Product;
MAX和MIN:计算最大值和最小值

注:MAX/MIN使用于任何数据类型,只要能排序,就存在最大值和最小值

-- 1.计算销售值的最大值和最小值
SELECT MAX(sale_price),MIN(purchase_price) FROM Product;
-- 2.计算日期的最大值和最小值
SELECT MAX(regist_date), MIN(regist_date) FROM Product;

注:MAX/MIN使用于任何数据类型,SUM/AVG只适用于数值类型的列。

使用聚合函数删除重复值(先去除重复行,再计算; AVG也可使用)
SELECT COUNT(DISTINCT product_type) FROM Product;

分组(GROUP BY)

-- 1.商品种类分组计算各组数量(GROUP BY指定的列被称为聚合列或分组列):
SELECT product_type, COUNT(*)
FROM Product
GROUP BY product_type;
-- 2.聚合键包含空值情况(空值也被当成一组):
SELECT purchase_price, COUNT(*)
FROM Product
GROUP BY purchase_price;
-- 3.同时使用where和GROUP BY子句
SELECT purchase_price, COUNT(*)
FROM Product
WHERE product_type = '衣服'
GROUP BY purchase_price;

注:

  • 使用group by时,select子句不能出现聚合键之外的列名。
  • 使用group by时,不能使用select子句中定义的列的别名。主要是sqld的执行顺序,先执行group by再执行select。
  • 使用group by 时,不能在where子句中使用聚合函数,只有select子句和having子句及group by子句中能够使用聚合函数

    如:
SELECT product_type, COUNT(*)
ROM Product
WHERE COUNT(*) = 2
GROUP BY product_type
> 1111 - Invalid use of group function
> 时间: 0s

为集合结果指定条件

注:HAVING子句中能够使用三种要素:常数,聚合函数,GROUP BY子句中指定的列名(聚合建)

HAVING子句:

  • 用having就一定要和group by连用
  • 用group by不一有having (它只是一个筛选条件用的)
 -- 1.分组,商品品种分组后结果中筛选出数据行数为2行的数据
SELECT product_type, COUNT(*)
FROM Product
GROUP BY product_type
HAVING COUNT(*) = 2;
 -- 2.平均数,销售价格大于2500的
SELECT product_type, AVG(sale_price)
FROM Product
GROUP BY product_type
HAVING AVG(sale_price) >= 2500;

相对于HAVING子句,更适合写再Where子句中的条件:

  • where子句 = 指定行所对应的条件
  • having子句 = 指定组所对应的条件
  • 聚合建所对应的条件不应该书写在HAVING子句中,而应书写在WHERE子句当中。
    • 虽执行结果一样,单更推荐第二种写法,将条件写在where子句中比写在having子句中的处理速度更快,返回结果时间更短。
    • 原因:聚合操作时,DBMS内部会进行排序处理,where在排序之前就对数据进行过滤,having是在排序之后在对数据进行分组。
SELECT product_type, COUNT(*)
FROM Product
GROUP BY product_type
HAVING product_type = '衣服'; SELECT product_type, COUNT(*)
FROM Product
WHERE product_type = '衣服'
GROUP BY product_type;

对结果进行排序

  • 升序:ASC(不写默认)
  • 降序:DESC

    select的排序顺序是随机的,通常在句尾添加ORDER BY(排序建)子句来明确排序。

    注:子句书写顺序:select - from - where - group by - having - order by
-- 1.销售价格升序:未指定GROUP BY子句中排列顺序默认为升序。
SELECT product_id, product_name, sale_price, purchase_price
FROM Product
ORDER BY sale_price;
-- 2.销售价格降序(DESC关键字)
SELECT product_id, product_name, sale_price, purchase_price
FROM Product
ORDER BY sale_price DESC;
-- 3.指定多个排序的键
SELECT product_id, product_name, sale_price, purchase_price
FROM Product
ORDER BY sale_price, product_id;

注:1.优先使用左侧的键,如果存在相同值则使用右侧。2.排序键包含null时,会在开头或者末尾进行汇总。

-- 4.在排序键中使用显示用的别名
SELECT product_id AS id, product_name, sale_price AS sp, purchase_price
FROM Product
ORDER BY sp, id;
-- 5.ORDER BY子句可以使用聚合函数
SELECT product_type, COUNT(*)
FROM Product
GROUP BY product_type
ORDER BY COUNT(*);

聚合函数与SQL排序的更多相关文章

  1. PCB MS CLR 聚合函数 joinString加排序实现

    准备着手,动态列SQL查询,要实现动态列SQL,会运用到聚合函数,而SQL本身聚合函数有限, 无满足此用户任意字段组合变化,再加上工艺流程重复相同工序,如;沉铜1,沉铜2对应工序代码都是相同的 而通常 ...

  2. Hibernate的批量查询——Criteria查询所有、条件、分页、统计(聚合函数)、排序

    1.查询所有的学生信息: public static void testSel() { Session session = HibernateUtils.openSession(); Transact ...

  3. SQL语句汇总(三)——聚合函数、分组、子查询及组合查询

    聚合函数: SQL中提供的聚合函数可以用来统计.求和.求最值等等. 分类: –COUNT:统计行数量 –SUM:获取单个列的合计值 –AVG:计算某个列的平均值 –MAX:计算列的最大值 –MIN:计 ...

  4. SQL 必知必会·笔记<7>汇总数据——使用聚合函数

    有时候我们需要对表中的数据进行汇总,而不需要数据本身,为了方便这些类型的检索,SQL给出了5个聚合函数,SQL聚合函数在各主要的SQL实现中得到了相当一致的支持.如下: 1.1 AVG()函数 AVG ...

  5. SQL语句汇总(三)——聚合函数、分组、子查询及组合查询

    拖了一个星期,终于开始写第三篇了.走起! 聚合函数: SQL中提供的聚合函数可以用来统计.求和.求最值等等. 分类: –COUNT:统计行数量 –SUM:获取单个列的合计值 –AVG:计算某个列的平均 ...

  6. 第16课-数据库开发及ado.net-数据库SQl,创建数据库和表,增删改语句,约束,top和Distinct,聚合函数介绍

    第16课-数据库开发及ado.net 数据库SQl,创建数据库和表,增删改语句,约束,top和Distinct,聚合函数介绍 SQL语句入门(脚本.命令) SQL全名是结构化查询语言(Structur ...

  7. SQL之开窗函数详解--可代替聚合函数使用

    在没学习开窗函数之前,我们都知道,用了分组之后,查询字段就只能是分组字段和聚合的字段,这带来了极大的不方便,有时我们查询时需要分组,又需要查询不分组的字段,每次都要又到子查询,这样显得sql语句复杂难 ...

  8. 【SQL】CLR聚合函数什么鬼

    之前写过一个合并字符串的CLR聚合函数,基本是照抄MS的示例,外加了一些处理,已经投入使用很长时间,没什么问题也就没怎么研究,近日想改造一下,遇到一些问题,遂捣鼓一番,有些心得,记录如下. 一.杂项 ...

  9. Oracle 聚合函数

    聚合函数: SQL中提供的聚合函数可以用来统计.求和.求最值等等. 此处采用Oracle 11g中其他用户SCOTT中的EMP表,进行演示. –COUNT:统计行数量 COUNT(*)统计的是结果集的 ...

随机推荐

  1. 清北学堂模拟赛d6t3 反击数

    分析:显然是一道数位dp题,不过需要一些奇怪的姿势.常规的数位dp能统计出一个区间内满足条件的数的个数,可是我们要求第k个,怎么办呢?转化为经典的二分问题,我们二分当前数的大小,看它是第几大的,就可以 ...

  2. Markdown 基本使用

    My First Markdown 标签(空格分隔): 未分类 # Markdown 11种基本语法## 设置标题在此输入正文标题设置(让字体变大,和word的标题意思一样)在Markdown当中设置 ...

  3. nyoj_37_回文字符串_201403121649

    回文字符串 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 所谓回文字符串,就是一个字符串,从左到右读和从右到左读是完全一样的,比如"aba".当 ...

  4. hdu_1031_Design T-Shirt_201310291647

    Design T-Shirt Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) T ...

  5. windows与linux下配置ant

    转自:http://www.cnblogs.com/wuxinrui/archive/2012/01/06/2314392.html 1.下载:到ANT官方网站http://ant.apache.or ...

  6. 每一个程序猿必知之SEO

    似乎由于受这篇文章的影响 http://katemats.com/what-every-programmer-should-know-about-seo/ 于是我也觉得我应该写一个每一个程序猿必知之S ...

  7. Oracle 11g OEM登录后提示“出现内部错误”

    使用oem登录时提示:“出现内部错误.有关详细信息, 请查看日志文件”. 具体原因未知,发现使用SQL Plus登录一次之后,再次登录即可.

  8. POJ 3653 &amp; ZOJ 2935 &amp; HDU 2722 Here We Go(relians) Again(最短路dijstra)

    题目链接: PKU:http://poj.org/problem? id=3653 ZJU:problemId=1934" target="_blank">http ...

  9. hdu 1010 Tempter of the Bone (奇偶性剪枝)

    题意:有一副二维地图'S'为起点,'D'为终点,'.'是可以行走的,'X'是不能行走的.问能否只走T步从S走到D? 题解:最容易想到的就是DFS暴力搜索,,但是会超时...=_=... 所以,,要有其 ...

  10. 多级联动系列——ajax调用XML实现三级联动

    ajax 使用起来特别的方便,再也不操心浏览器兼容问题了.用ajax调用XML页面中的内容,来生成三级联动,OK废话不多说,跟着我一步步写吧. 首先写一个XML文件.data.xml <?xml ...