《SQL 必知必会》读书笔记 -- 第9课 汇总数据

9.1 聚集函数:对某些行运行的函数,计算并返回一个值
  案例:
  -- 确定表中函数
  -- 获得表中某些行的和
  -- 找出表列的最大值、最小值和平均值等

  --当我们实际想要汇总信息,而不是需要数据本身时,可节省时间和带宽。

  --表9-1
  --函数      说明
  --AVG()    返回某列的平均值
  --COUNT()   返回某列的行数
  --MAX()    返回某列的最大值
  --MIN()    返回某列的最小值
  --SUM()    返回某列值之和

9.1.1 AVG()  函数:返回某列的平均值

 SELECT AVG(prod_price) AS avg_price
FROM dbo.Products;
--分析:此 avg_price 包含 Products 表中所有产品的平均价格

SELECT AVG(prod_price) AS avg_price
FROM dbo.Products
WHERE vend_id = 'DLL01';
--分析:WHERE 过滤出 vend_id 为 DLL01 的产品,因此 avg_price 返回的值只是该供应商产品的平均值

  【注意】AVG()  函数忽略列值为 NULL 的行

9.1.2 COUNT()  函数:确定表中行的数目或符合特定条件的行的数目
-- 使用方式:
-- 使用 COUNT(*) 对表中行的数目进行技术,不管表列中包含的是空值(NULL)还是非空值
-- 使用 COUNT(column) 对特定列中具有值的行进行计数,忽略 NULL 值

SELECT COUNT(*) AS num_cust
FROM dbo.Customers;
--返回Customers表中的顾客数

SELECT COUNT(cust_email) AS num_cust
FROM dbo.Customers;
--这里只对具有电子邮件地址的客户进行计数,结果为3,表示5个顾客中只有3个顾客有电子邮件
--分析:因为这里指定了列名,COUNT()会忽略指定列的值为空的行

9.1.3 MAX() 函数:返回指定列中的最大值
--要求:指定列名

SELECT MAX(prod_price) AS max_price
FROM dbo.Products;
--返回的是Products表中最贵重的物品的价格

  【注意】MAX() 忽略列值为NULL的行

9.1.4 MIN() 函数:与 MAX() 相反,返回指定列的最小值。
--要求:指定列名

SELECT MIN(prod_price) AS min_price
FROM dbo.Products;
--返回的是Products表中最便宜的物品的价格

  【注意】MIN() 忽略列值为 NULL 的行

9.1.5 SUM() 函数:返回指定列值的总和(总计)

SELECT SUM(quantity) AS items_ordered
FROM dbo.OrderItems
WHERE order_num = 20005;
--分析:SUM(quantity)返回订单中所有物品数量之和,WHERE 子句保证只统计某个物品订单中的物品

SELECT SUM(item_price*quantity) AS total_price
FROM dbo.OrderItems
WHERE order_num = 20005;
--分析:SUM(item_price*quantity) 返回订单中所有物品价钱之和,WHERE 子句保证值统计某个物品订单中的物品

  【注意】SUM() 忽略列值为 NULL 的行

9.2 聚集不同的值
--以上5个聚集函数都可以使用:DISTINCT 参数,只包含不同的值

SELECT AVG(DISTINCT prod_price) AS avg_price
FROM dbo.Products
WHERE vend_id = 'DLL01';
--因为使用了 DISTINCT 参数,因此平均值只考虑各个不同的价格

  【注意】DISTINCT 不能用于 COUNT(*) ,但可用于 COUNT(column)
  【提示】虽可用于 MIN() 和 MAX() ,但这样没有实际价值

9.3 组合聚集函数

SELECT COUNT(*) AS num_items,
MIN(prod_price) AS price_min,
MAX(prod_price) AS price_max,
AVG(prod_price) AS price_avg
FROM dbo.Products;
--使用单条SELECT语句执行了4个聚集计算,返回4个值(Products表中物品的数目,产品价格的最高值、最低值以及平均值)
--使用聚集函数建议取别名让数据更清晰

T-SQL:毕业生出门需知系列(九)的更多相关文章

  1. T-SQL:毕业生出门需知系列(四)

    第4课 过滤数据 4.1 使用 WHERE 子句:过滤 只检索所需数据需要指定搜索条件(即过滤条件). WHERE 子句在表名(FROM 子句)后给出,根据 WHERE 子句中指定的条件过滤. SEL ...

  2. T-SQL:毕业生出门需知系列(二)

    第2课 检索数据 2.1 SELECT 语句 用途:从一个或多个表中检索数据信息 关键字:作为SQL组成部分的保留字.关键字不能用作表或列的名字. 为了使用SELECT检索表数据,必须至少给出两条信息 ...

  3. T-SQL:毕业生出门需知系列(目录)

    一.前言: 作为一个应届毕业生又要准备面试 ASP.NET 攻城狮了,以前在图书馆觉得这本书讲得挺基础,这次回家就自己买了本用来复习,顺便做下读书笔记. 第4版 二.代码下载: 官方:http://f ...

  4. T-SQL:毕业生出门需知系列(八)

    第8课 使用函数处理数据 8.1 函数 [名词]可移植:所编写的代码可以在多个系统上运行 8.2 使用函数 8.2.1 文本处理函数 例1:使用 UPPER() 函数--将文本转换为大写 SELECT ...

  5. T-SQL:毕业生出门需知系列(七)

    第7课 创建计算字段 7.1 计算字段(格式化字段) 存储在数据库表中的数据一般不是应用程序所需要的格式,如: 1.需要显示公司名,同时还需要显示公司的地址,但这两个信息存储在不同的表列中. 2.列数 ...

  6. T-SQL:毕业生出门需知系列(六)

    第6课 用通配符进行过滤 6.1 LIKE 操作符 前面介绍的所有操作符都是针对已知值进行过滤.但是,这种过滤方法并不是任何时候都好用. 例如:怎样搜索产品名中包含文本 bean bag 的所有产品? ...

  7. T-SQL:毕业生出门需知系列(五)

    第5课 高级数据过滤 5.1 组合 WHERE 子句 第4课介绍的 WHERE 子句在过滤数据时都是用单一的条件. 5.1.1 AND 操作符 检索由供应商 DLL01 制造且价格小于等于 4 美元的 ...

  8. T-SQL:毕业生出门需知系列(三)

    第3课 排序检索数据 3.1 排序数据(ORDER BY) 下面的 SQL 语句返回某个数据库表的单个列.观察其输出,并没有特定的顺序. SELECT prod_name FROM Products; ...

  9. SQL Server 2008空间数据应用系列九:使用空间工具(Spatial Tools)导入ESRI格式地图数据

    转自:http://www.cnblogs.com/beniao/archive/2011/03/22/1989310.html 友情提示,您阅读本篇博文的先决条件如下: 1.本文示例基于Micros ...

随机推荐

  1. 使用 .NET WinForm 开发所见即所得的 IDE 开发环境,实现不写代码直接生成应用程序

    直接切入正题,这是我09年到11年左右业余时间编写的项目,最初的想法很简单,做一个能拖拖拽拽就直接生成应用程序的工具,不用写代码,把能想到的业务操作全部封装起来,通过配置的方式把这些业务操作组织起来运 ...

  2. 结巴分词3--基于汉字成词能力的HMM模型识别未登录词

    作者:zhbzz2007 出处:http://www.cnblogs.com/zhbzz2007 欢迎转载,也请保留这段声明.谢谢! 1 算法简介 在 结巴分词2--基于前缀词典及动态规划实现分词 博 ...

  3. scrapy 知乎用户信息爬虫

    zhihu_spider 此项目的功能是爬取知乎用户信息以及人际拓扑关系,爬虫框架使用scrapy,数据存储使用mongo,下载这些数据感觉也没什么用,就当为大家学习scrapy提供一个例子吧.代码地 ...

  4. jQuery学习之路(7)- 用原生JavaScript实现jQuery的某些简单功能

    ▓▓▓▓▓▓ 大致介绍 学习了妙味,用原生的JavaScript实现jQuery中的某些部分功能 定义自己的函数库lQuery ▓▓▓▓▓▓ $()选择器的实现 jQuery是面向对象的,所以自己编写 ...

  5. Lambda

    Lambda Lambda 表达式是一种可用于创建委托或表达式目录树类型的匿名函数. 通过使用 lambda 表达式,可作为参数传递或作为函数调用值返回的本地函数. Lambda 表达式对于编写 LI ...

  6. 个人网站对xss跨站脚本攻击(重点是富文本编辑器情况)和sql注入攻击的防范

    昨天本博客受到了xss跨站脚本注入攻击,3分钟攻陷--其实攻击者进攻的手法很简单,没啥技术含量.只能感叹自己之前竟然完全没防范. 这是数据库里留下的一些记录.最后那人弄了一个无限循环弹出框的脚本,估计 ...

  7. c# Enumerable中Aggregate和Join的使用

    参考页面: http://www.yuanjiaocheng.net/ASPNET-CORE/asp.net-core-environment.html http://www.yuanjiaochen ...

  8. Flexible 弹性盒子模型之CSS flex-flow

    实例 让弹性盒的元素以相反的顺序显示,且在必要的时候进行拆行: display:flex; flex-flow:row-reverse wrap;   效果预览 浏览器支持 表格中的数字表示支持该属性 ...

  9. Android中通过ActionBar为标题栏添加搜索以及分享视窗

    在Android3.0之后,Google对UI导航设计上进行了一系列的改革,其中有一个非常好用的新功能就是引入的ActionBar,他用于取代3.0之前的标题栏,并提供更为丰富的导航效果.Action ...

  10. Linux基础介绍【第八篇】

    Linux网络基础 网线 568A 568B 线序:橙白橙 绿白蓝 蓝白绿 棕白棕 交换机.路由器 交换机:DLINK.H3C.CISCO 交换机(Switch)是一种用于电信号转发的网络设备.它可以 ...