8.聚集函数 ---SQL

一、AVG()函数



  A VG()通过对表中行数计数并计算其列值之和,求得该列的平均值。A VG()可用来返回所有列的平均值,也可以用来返回特定列或行的平均值。

警告:只用于单个列
  AVG()只能用来确定特定数值列的平均值,而且列名必须作为函数参数给出。为了获得多个列的平均值,必须使用多个A VG()函数。
说明:NULL值
  A VG()函数忽略列值为NULL的行。

二、COUNT()函数



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

SELECT COUNT(*) AS num_cust
FROM Customers;
输出▼
num_cust
--------
5

分析▼

在此例子中,利用COUNT(*)对所有行计数,不管行中各列有什么值

SELECT COUNT(cust_email) AS num_cust
FROM Customers;
输出▼
num_cust
--------
3

分析▼
  这条SELECT语句使用COUNT(cust_email)对cust_email列中有值的行进行计数。在此例子中,cust_email的计数为3(表示5个顾客中只有3个顾
客有电子邮件地址)。

说明:NULL值
  如果指定列名,则COUNT()函数会忽略指定列的值为空的行,但如果COUNT()函数中用的是星号(*),则不忽略。

三、MAX()函数



MA X()返回指定列中的最大值。MA X()要求指定列名,

提示:对非数值数据使用MAX()
  虽然MA X()一般用来找出最大的数值或日期值,但许多(并非所有)DBMS允许将它用来返回任意列中的最大值,包括返回文本列中的最大
值。在用于文本数据时,MA X()返回按该列排序后的最后一行。
说明:NULL值
  MA X()函数忽略列值为NULL的行。

四、MIN()函数



MIN()的功能正好与MA X()功能相反,它返回指定列的最小值。与MA X()一样,

提示:对非数值数据使用MIN()
虽然MIN()一般用来找出最小的数值或日期值,但许多(并非所有)DBMS允许将它用来返回任意列中的最小值,包括返回文本列中的最小
值。在用于文本数据时,MIN()返回该列排序后最前面的行。
 
说明:NULL值
MIN()函数忽略列值为NULL的行。

五、SUM()函数



SUM()用来返回指定列值的和(总计)。

提示:在多个列上进行计算
利用标准的算术操作符,所有聚集函数都可用来执行多个列上的计算。
 
说明:NULL值
SUM()函数忽略列值为NULL的行。

六、聚集不同值



以上5个聚集函数都可以如下使用:

  • 对所有行执行计算,指定A LL参数或不指定参数(因为A LL是默认行为)。
  • 只包含不同的值,指定DISTINCT参数。

提示:ALL为默认
  A LL参数不需要指定,因为它是默认行为。如果不指定DISTINCT,则假定为A LL。
说明:不要在Access中使用
  Microsoft Access在聚集函数中不支持DISTINCT,因此下面的例子不适合于Access。要在Access得到类似的结果,需要使用子查询
  把DISTINCT数据返回到外部SELECT COUNT(*)语句。

SELECT AVG(DISTINCT prod_price) AS avg_price
FROM Products
WHERE vend_id = ‘DLL01‘;

分析▼
在使用了DISTINCT后,结果可能会发生变化。排除它们重复值提升或降低了平均值。

警告:DISTINCT不能用于COUNT(*)
  如果指定列名,则DISTINCT只能用于COUNT()。DISTINCT不能用于COUNT(*)。类似地,DISTINCT必须使用列名,不能用于计算或表达
式。
提示:将DISTINCT用于MIN()和MAX()
  虽然DISTINCT从技术上可用于MIN()和MA X(),但这样做实际上没有价值。一个列中的最小值和最大值不管是否只考虑不同值,结果都是相
同的。
说明:其他聚集参数
  除了这里介绍的DISTINCT和A LL参数,有的DBMS还支持其他参数,如支持对查询结果的子集进行计算的TOP和TOP PERCENT。为了解具
体的DBMS支持哪些参数,请参阅相应的文档。

七、组合聚集函数


SELECT COUNT(*) AS num_items,
MIN(prod_price) AS price_min,
MAX(prod_price) AS price_max,
AVG(prod_price) AS price_avg
FROM Products;

分析▼
  这里用单条SELECT语句执行了4个聚集计算,返回4个值(Products表中物品的数目,产品价格的最高值、最低值以及平均值)。
警告:取别名
  在指定别名以包含某个聚集函数的结果时,不应该使用表中实际的列名。虽然这样做也算合法,但许多SQL实现不支持,可能会产生模糊的
错误消息。

时间: 2024-10-13 08:54:16

8.聚集函数 ---SQL的相关文章

SQL中的5种聚集函数

原文:SQL中的5种聚集函数 作为一个刚毕业进入这行的菜鸟,婶婶的觉的那种大神.大牛到底是怎样炼成的啊,我这小菜鸟感觉这TMD要学的东西这多啊,然后就给自己定了许多许多要学习的东西,可是有人又不停地给你灌输:东西不在多而要精通!我也觉得很有道理,可是怎样才能精通呢?封神之路,在哪里啊 !!! 这一天没有一个安静的心,基本是学不进去了,发现自己还是太功利了,急功近利!也许你只要学就行,管他是否能够立即让人见识到你的厉害,技术和知识这种东西也许还是要强调一个 底蕴的.既然自己最烦那种看了两篇文章就给

hiberante对象方式的投影操作与sql语句的投影方式(聚集函数的hibernate用法)

hiberante对象方式的投影操作与sql语句的投影方式(聚集函数的hibernate用法) 最近用到了hibernate的投影,写日记出来记录一下. (⊙o⊙)… 前提:搭配好hibernate环境了. myclass指的是已经映射好的实体类 如下3个函数是我写来测试投影的方法:   此三个方法我写在basedao中(基础dao类,做常用dao操作) 1 /** 2 * 斌临城下增加! 3 * <p/> 4 * ---(⊙o⊙)… 5 * <p/> 6 * * 7 */ 8 p

Sql学习笔记3——集合运算、空值和聚集函数

1.集合运算 SQL作用在关系上的union.intersect和except(Oracle中用minus代替except)运算,对应于数学集合论中的并.交和差运算.这三个运算都自动去除重复. eg: 找出在2009年秋季学期开课但不在2010年春季开课的所有课程 (select course_id from section where semester=‘Fall’ and year=2009) except (select course_id from section where semes

Oracle自定义聚集函数

今天工作中看见别人写的自定义聚集函数,所以一门心思的想搞懂,就在网上找资料了. 自定义聚集函数 自定义聚集函数接口简介 Oracle提供了很多预定义好的聚集函数,比如Max(), Sum(), AVG(), 但是这些预定义的聚集函数基本上都是适应于标量数据(scalar data), 对于复杂的数据类型,比如说用户自定义的Object type, Clob等, 是不支持的. 但是,幸运的是, 用户可以通过实现Oracle的Extensibility Framework中的ODCIAggregat

Hibernate 笔记 HQL查询 条件查询,聚集函数,子查询,导航查询

本笔记继续使用dept部门表,emp员工表,一对多多对一双向映射. 1 条件查询 1.1    查询 员工表emp中 年龄eage小于30,月薪esal大于20000的员工姓名ename sql:select ename from emp where eage<? and esal >?; hql: select ename from Emp where eage<? and esal >? 1.2 问号的设置与别名 问号(?)的设置使用.setParameter(位置, 属性值)

MySQL创建字段+数据处理函数+汇总数据(聚集函数)+分组数据

[0]README 0.1)本文部分文字描述转自"MySQL 必知必会",旨在review"MySQL创建字段+数据处理函数+汇总数据(聚集函数)+分组数据" 的基础知识: [1]创建计算字段 1)problem+solution 1.1)problem:存储在表中的数据都不是应用程序所需要的.我们需要直接从数据库中检索出转换,计算或格式化过的数据: 1.2)solution:这就是计算字段发挥作用所在了, 计算字段是运行时在 select语句内创建的: 2)字段定

DBMS-SQL、聚集函数、嵌套子查询、数据库修改

SQL SQL:结构化查询语言,分为以下几个部分. ·数据定义语言(Data-Definition Language, DDL):SQL DDL提供定义定义关系模式.删除关系以及修改关系模式的命令. ·数据操纵语言(Data-Manipulation Language, DML):SQL DML包括查询语言,以及在数据库中插入元组.删除元组和修改元组的命令. ·完整性(integrity):SQL DDL包括定义完整性约束的命令,保存在数据库中的数据必须满足所定义的完整性约束,不允许破坏完整性约

substring函数——sql

--substring( expression, start, length ) expression待截取的文字 start 截取位置的起始下标 length 要截取的长度 --左边第一个字符的下标为1,比如截取字符a,从第一个字符开始截取一个长度 select substring('abcd',1,1) --如果你的起始位置下标写成了0,那么截取字符a就要把长度写成2 select substring('abcd',0,2) --如果你的起始位置下标写成了-1,那么截取字符a就要把长度写成3

聚集函数

5个聚集函数 1.AVG() 返回某列的平均值 只能用于单个列 忽略列值为NULL的行 2.COUNT() 返回某列的行数 COUNT(*) 对表中行的数目进行计数,不管列中包含的是空值还是非空值 COUNT(column) 对特定列中具有值的行进行计数,忽略NULL值 3.MAX() 返回某列的最大值,忽略NULL 4.MIN() 返回某列的最小值,忽略NULL 5.SUM() 返回某列值的和,忽略NULL 聚集不同值 ALL 默认值,对所有行 DISTINCT 包含不同的值