SQL语言基本操作(聚合函数)
一、聚合函数
1、标量函数:只能对单个的数字或值进行计算。主要包括字符函数、日期/时间函数、数值函数和转换函数这四类。如LEFT/RIGHT/SUBSTRING/LTRIM/RTRIM/CONCAT/UPPER/LOWER/NOW/CURRENT_DATE/DATE_FORMAT/RAND/IFNULL等函数。
2、聚合函数意味着用于分组数据。常用的有SUM、COUNT、AVG、MIN和MAX等函数。下面将对其进行适当说明:
2.1、COUNT函数
首先,COUNT函数可以用来返回所有选中行的数目,而不管任何特定的列;其次,COUNT可以指定一个具体的列而不是星号;最后,允许我们除了使用列名还可以使用关键字DISTINCT。
注意:COUNT函数只计算存在的情况,对值为NULL的情况不计算在内。
相关执行SQL语句和执行代码:
2.2、分组数据
使用关键字GROUP BY 把SELECT 语句返回的数据分成任意数目的组,一旦进行分组,使用聚合函数对其进行汇总统计。具体示例如下:
注意:若某行的Grade值为NULL时,计算平均值时会忽略带有NULL值得那一行。如果想要把NULL当做0,那么可以使用ISNULL函数把NULL转换成0,如下所示:
AVG(ISNULL(Grade,0)) AS ’Average Grade‘;即可。
2.3、基于聚合查询条件
汇总数据,一旦创建了组,查询条件就会变得更加复杂。针对带GROUP BY 的一条SELECT 语句应用于任何查询条件,必须要询问查询条件是应用于单独的行还是 整个组。实际上,WHERE子句是对单独行执行查询条件。HAVING 的关键字,允许对组级别使用查询条件。
注意:所有的列必须要么出现在GROUP BY中,要么包含在一个聚合函数中。
一般格式如下:SELECT columnlist
FROM tablelist
WHERE condition
GROUP BY columnlist
HAVING condition
ORDER BY columnlist;
强调一点:当在SELECT语句中使用上面任意一个关键字时,都需要按照这里给定的顺序输入。如关键字HAVING总要放在GROUP BY之后,ORDER BY之前。
二、小结
聚合函数与GROUP BY组合使用时是体现真正强大之处,他允许针对划分成组的数据进行真正的聚合。而HAVING关键字的使用,允许我们对聚合函数的值应用组级别的查询条件。
SQL语言基本操作(聚合函数)的更多相关文章
- sql语句 之聚合函数
聚合分析 在访问数据库时,经常需要对表中的某列数据进行统计分析,如求其最大值.最小值.平均值等.所有这些针对表中一列或者多列数据的分析就称为聚合分析. 在SQL中,可以使用聚合函数快速实现数据的聚 ...
- SQL Server 自定义聚合函数
说明:本文依据网络转载整理而成,因为时间关系,其中原理暂时并未深入研究,只是整理备份留个记录而已. 目标:在SQL Server中自定义聚合函数,在Group BY语句中 ,不是单纯的SUM和MAX等 ...
- 【SQL】CLR聚合函数什么鬼
之前写过一个合并字符串的CLR聚合函数,基本是照抄MS的示例,外加了一些处理,已经投入使用很长时间,没什么问题也就没怎么研究,近日想改造一下,遇到一些问题,遂捣鼓一番,有些心得,记录如下. 一.杂项 ...
- SQL中的聚合函数
聚合函数是对一组值执行计算并返回单一的值的函数,它经常与SELECT语句的GROUP BY子句一同使用,SQL SERVER 中具体的聚合函数如下:1. AVG 返回指定组中的平均值,空值被忽略. 例 ...
- SQL中的聚合函数运用
参考网址: https://zhuanlan.zhihu.com/p/245115561 聚合函数是什么 聚合函数是对一组值执行计算,并返回单个值的函数.常与 SELECT 语句的 GROUP BY ...
- SQL server 数据库 ——聚合函数(一列 多行,值类型)
聚合函数 5种函数: 1.max最大值 select max(price) from car where code='c024' 2.min最小值 select * from car wher ...
- 数据库系统学习(六)-SQL语言基本操作
第六讲 SQL语言概述 基本命名操作 关系代数是集合的思想 关系演算是逻辑的思想(数学公式) SQL-86,SQL-89,SQL-92,SQL-99,SQL-2003,2008...发展过程标准 SQ ...
- sql group by聚合函数
如何让分组后count计算结果为0的记录也显示
- 2019-1-11 SQL语句汇总——聚合函数、分组、子查询及组合查询
随机推荐
- java8新特性——简介
java8问世已经有好长时间了,但是之前项目中都没有使用到,所以一直都只是了解一些,近期刚刚换了家新公司,在开发中需要使用到java8来开发,所以也是马上赶来学习一下java8得新特性. 一.新特性 ...
- Loj10086 Easy SSSP
试题描述 输入数据给出一个有 N 个节点,M 条边的带权有向图.要求你写一个程序,判断这个有向图中是否存在负权回路.如果从一个点沿着某条路径出发,又回到了自己,而且所经过的边上的权和小于 0,就说 ...
- [转]Android中常用适配器及定义自己的适配器
一,适配器. 顾名思义,就是把一些数据给弄得适当,适合以便于在View上显示.可以看作是界面数据绑定的一种理解.它所操纵的数据一般都是一些比较复杂的数据,如数组,链表, 数据库,集合等.适配器就像 ...
- Codeforces Beta Round #7 A. Kalevitch and Chess 水题
A. Kalevitch and Chess 题目连接: http://www.codeforces.com/contest/7/problem/A Description A famous Berl ...
- 微信、小程序开发UI库--weui
一.weui可以开发微信内网页.微信小程序,二者使用的UI库不一样 1. 微信内网页样式文件为 .css文件 链接地址:https://weui.io/ weui-js库: weu ...
- BeanPostProcessor使用心得
最近想对项目中的所有bean进行一个代理.然后监控bean得方法的使用情况. 刚开始想的方法是:重写项目的beanFactory,然后再getBean的使用,对结果object进行一个 ...
- Android中MVC模型(复合模式)
mvc是model,view,controller的缩写,mvc包括三个部分: 1.模型(model)对象:是应用程序的主体部分,全部的业务逻辑都应该写在该层. 2.视图(view)对象:是应用程序中 ...
- Jquery UI 中Tree组件的json格式,java递归拼接demo
数据库中表数据,如下图: 实现的需求是,如果suporgcode数据为null 的情况下,表示在一级节点 "请选择" 的二级节点,然后是如:3和36 是1的子节点,一步一步的节点延 ...
- shell之if简化语句
最常用的简化if语句: && 如果是“前面”,则“后面” [ -f /var/run/dhcpd.pid ] && rm /var/run/dhcpd.pid 检查 文 ...
- 解决office2007-安装程序找不到office.zh-cn\Setup.xml
安装Microsoft Office Project Standard 2007时出现了小问题,经过百度google一番后才发现安装office2007与安装vs2008有着紧密的联系,参见:http ...