实例详解Sql Server 所有聚合函数--【叶子】
一、Sql Server 中有哪些聚合函数?
提到聚合函数大家一定会首先想到最常用的:
1、 求个数:count
2、 求总和:sum
3、 求最大值:max
4、 求最小值:min
5、 求平均值:avg
聚合函数中有四个函数是我一直以来几乎就没有用到过的:
1、 求方差:var
2、 求总体方差:varp
3、 标准偏差:stdev
4、 求总体标准偏差:stdevp
除此以外Sql Server中还有几个集合函数:
1、 求校验和:checksum_agg
2、 求个数:count_big
3、 用于测试 cube 或 rollup 空值:grouping
二、聚合函数在什么情况下使用?
聚合函数只能在以下位置作为表达式使用:
1、 select 语句的选择列表(子查询或外部查询)。
2、 compute 或 compute by 子句。
3、having 子句。
三、聚合函数count和count_big的区别?
count_big的用法与count 函数类似。两个函数唯一的差别是它们的返回值。count_big始终返回 bigint 数据类型值。count始终返回 int 数据类型值。
四、应用实例
if object_id("[tb]") is not null drop table [tb] create table [tb] (id int,num int) insert into [tb] select 1,92 union all select 2,94 union all select 3,96 union all select 4,98 union all select 5,100 --求个数 select count(*) as 行数from [tb] /*5*/ --求总和 select sum(num) as 总和from [tb] /*480*/ --求最大值 select max(num) as 最大值from [tb] /*100*/ --求最小值 select min(num) as 最小值from [tb] /*92*/ --求平均值 select avg(num) as 平均值from [tb] /*96*/ --求方差 select var(num) as 方差from [tb] /*10*/ --求总体方差 select varp(num) as 总体方差from [tb] /*8*/ --求标准偏差 select stdev(num) as 标准偏差from [tb] /*3.16227766016838*/ --求总体标准偏差 select stdevp(num) as 总体标准偏差from [tb] /*2.82842712474619*/ --求校验和 select checksum_agg(num) as 校验和from [tb] /*100*/ --求个数 select count_big(num) as 行数from [tb] /*5*/ --grouping select isnull(ltrim(id),"合计") as id, sum(num) as num, grouping(id) as "sgin" from [tb] group by id with rollup /* id num sgin ------------ ----------- ---- 1 92 0 2 94 0 3 96 0 4 98 0 5 100 0 合计 480 1 */
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: 常用的聚合函数
- 下一篇: 【数据库】数据聚合的概念?