iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >SQL中的常用聚合函数是什么
  • 280
分享到

SQL中的常用聚合函数是什么

2023-06-06 02:06:49 280人浏览 薄情痞子
摘要

sql中的常用聚合函数是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1)COUNT语法:COUNT(e1)参数:e1为一个表达式,可以是任意的数据类型返回:返回数值型数据

sql中的常用聚合函数是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

1)COUNT

语法:COUNT(e1)

参数:e1为一个表达式,可以是任意的数据类型

返回:返回数值型数据

作用:返回e1指定列不为空的记录总数

2)SUM,

语法:SUM(e1)

参数:e1为类型为数值型的表达式

返回:返回数值型数据

作用:对e1指定的列进行求和计算

3)MIN, MAX

语法:MIN(e1)、MAX(e1)

参数:e1为一个字符型、日期型或数值类型的表达式。

若e1为字符型,则根据ASCII码来判断最大值与最小值。

返回:根据e1参数的类型,返回对应类型的数据。

作用:MIN(e1)返回e1表达式指定的列中最小值;

     MAX(e1)返回e1表达式指定的列中最大值;

4)AVG

语法:AVG(e1)

参数:e1为一个数值类型的表达式

返回:返回一个数值类型数据

作用:对e1表达式指定的列,求平均值。

5)MEDIAN

语法:MEDIAN(e1)

参数:e1为一个数值或日期类型的表达式

返回:返回一个数值或日期类型的数据

作用:首先,根据e1表达式指定的列,对值进行排序

若排序后,总记录为奇数,则返回排序队列中,位于中间的值;

若排序后,总记录为偶数,则对位于排序队列中,中间两个值进行求平均,返回这个平均值;

6)RANK

1)用法1:RANK OVER

  语法:RANK( )  OVER ([ PARTITioN BY column1 ] ORDER BY column2 [ASC|DESC])

为分析函数,为每条记录产生一个序列号,并返回。

  参数:column1为列名,指定按照哪一列进行分类(分组)

 column2为列名,指定根据哪列排序,默认为升序;

 若指定了分类子句(PARTITION BY),则对每类进行排序(每个分类单独排序)

  返回:返回一个数值类型数据,作为该记录的序号!

  作用:为分析函数,对记录先按column1分类,再对每个分类进行排序,并为每条记录分配一个序号(每个分类单独排序)

  注意:排序字段值相同的记录,分配相同的序号。存在序号不连续的情况

  实例:student表记录了学生每科的成绩,要求按学科排序,并获取每科分数前两名的记录

student表如下:

SQL> select * from student order by kemu;

 NAME       ID                KEMU      FENSHU

---------- -------------- -------------- ----------------

Li            0113101     物理               80

Luo         0113011     物理               80

Wang     0113077     物理               70

Zhang     0113098    物理               90

Luo         0113011     高数               80

Wang      0113077    高数               70

Zhang     0113098    高数               80

Li             0113101    高数               90

 8 rows selected

按学科分类,按成绩排序(降序)

SQL> select rank() over(partition by KEMU order by FENSHU desc) as sort,student.* from student;

       SORT    NAME        ID              KEMU      FENSHU

---------- ---------- ---------------- ------------ ----------

         1            Zhang      0113098    物理               90

        2            Li              0113101    物理               80

         2            Luo           0113011    物理               80

         4            Wang       0113077    物理               70

         1            Li              0113101    高数               90

         2            Luo           0113011    高数               80

         2            Zhang      0113098    高数               80

         4            Wang       0113077    高数               70

由返回记录可了解,对排序列的值相同的记录,rank为其分配了相同的序号(SORT NAME列)。

并且之后的记录的序号是不连续的。

若获取每科前两名,只需对排序后的结果增加二次查询即可

select * from 

(select rank() over(partition by KEMU order by FENSHU desc) as sort_id,student.* from student) st 

where st.sort_id<=2;

2)用法2:RANK WITHIN GROUP

语法: RANK( expr1 ) WITHIN GROUP ( ORDER BY expr2 )

为聚合函数,返回一个值。

参数:expr1为1个或多个常量表达式;

        expr2为如下格式的表达式:

             expr2的格式为'expr3 [ DESC | ASC ] [ NULLS { FIRST | LAST } ]'

其中,expr1需要与expr2相匹配,

即:expr1的常量表达式的类型、数量必须与ORDER BY子句后的expr2表达式的类型、数量相同

实际是expr1需要与expr3相匹配

如:RANK(a) WITHIN GROUP (ORDER BY b ASC NULLS FIRST);

   其中,a为常量,b需要是与相同类型的表达式

   RANK(a,b) WITHIN GROUP (ORDER BY c DESC NULLS LAST, d DESC NULLS LAST);

   其中,a与b都为常量;c是与a类型相同的表达式、d是与b类型相同的表达式;

返回:返回数值型数据,该值为假定记录在表中的序号。

作用:确定一条假定的记录,在表中排序后的序号。

  如:假定一条记录(假设为r1)的expr2指定字段值为常量expr1,则将r1插入表中后,

与原表中的记录,按照ORDER BY expr2排序后,该记录r1在表中的序号为多少,返回该序号。

注释: NULLS FIRST指定,将ORDER BY指定的排序字段为空值的记录放在前边;

NULLS LAST指定,将ORDER BY指定的排序字段为空值的记录放在后边;

实例:假设一个员工的薪水为1500,求该员工的薪水在员工表中的排名为多少?

已知员工表如下:

SQL> select * from employees;

EMP_ID     EMP_NAME     SALARY

---------- -------------------- ---------------

10001      ZhangSan             500

10002      LiSi                         1000

10003      WangWu               1500

10004      MaLiu                     2000

10005      NiuQi                      2500

SQL> select rank(1500) within group (order by salary) as "rank number" from employees;

rank number

-----------

          3

由结果可知,薪水为1500的员工,在表中按升序排序,序号为3

7)FIRST、LAST

语法:agg_function(e1) KEEP (DENSE_RANK FIRST ORDER BY e2 [NULLS {FIRST|LAST}]) [OVER PARTITION BY e3 ]

agg_function(e1) KEEP (DENSE_RANK LAST  ORDER BY e2 [NULLS {FIRST|LAST}]) [OVER PARTITION BY e3 ]      

参数:agg_function为一个聚合函数,可以为 MIN、MAX、SUM、AVG、COUNT、VARIANCE或STDDEV

e2指定以哪个字段为依据,进行排序;

e3指定以哪个字段为依据,进行分类(分组);

当指定OVER PARTITION BY子句后,针对分类后的每个类单独排序;

DENSE_RANK为排序后的记录分配序号,并且序号为连续的。

NULLS {FIRST|LAST}指定排序字段e1的值若为空,则拍在序列前边(NULLS FIRST)或者后边(NULLS LAST)

DENSE_RANK后的FIRST/LAST确定选取通过DENSE_RANK排好序后的序列中,序号最小/最大的记录。序号相同时,返回多条记录

当序号相同,返回多条记录时,agg_function(e1)聚合函数继续对这多条记录的e1字段做聚合操作。

作用:如果agg_function为min(e1),获取排序后的FIRST或LAST的多条记录中,某字段e1的最小值

该字段不是排序关键字段e2

实例:

已知员工表有薪水字段,奖金字段。要求获取薪水最低的员工中,奖金最高的员工的记录。

已知表内容如下:

SQL> select * from employees order by salary;

 EMP_ID     EMP_NAME           SALARY  COMMISSION

---------- ---------------------------- ------------  ------------

10001      ZhangSan                    500        200

10002      LiSi                                500        300

10003      WangWu                      500        100

10004      MaLiu                           2000       500

10005      NiuQi                            2500       200

10006      ShangDuo                   2500       300

10007      BaiQi                             2500       400

SQL> select max(commission) keep(dense_rank first order by salary asc) as commission from employees;

COMMISSION

----------

       300

首先,按salary排序后,获取薪水最低的记录,分别为员工10001、10002、10003三条记录。

聚合函数max(commission)对3条记录获取奖金最高的为员工10002,奖金为300。

看完上述内容,你们掌握SQL中的常用聚合函数是什么的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网精选频道,感谢各位的阅读!

--结束END--

本文标题: SQL中的常用聚合函数是什么

本文链接: https://www.lsjlt.com/news/245834.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++ 生态系统中流行库和框架的贡献指南
    作为 c++++ 开发人员,通过遵循以下步骤即可为流行库和框架做出贡献:选择一个项目并熟悉其代码库。在 issue 跟踪器中寻找适合初学者的问题。创建一个新分支,实现修复并添加测试。提交...
    99+
    2024-05-15
    框架 c++ 流行库 git
  • C++ 生态系统中流行库和框架的社区支持情况
    c++++生态系统中流行库和框架的社区支持情况:boost:活跃的社区提供广泛的文档、教程和讨论区,确保持续的维护和更新。qt:庞大的社区提供丰富的文档、示例和论坛,积极参与开发和维护。...
    99+
    2024-05-15
    生态系统 社区支持 c++ overflow 标准库
  • c++中if elseif使用规则
    c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
    99+
    2024-05-15
    c++
  • c++中的继承怎么写
    继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
    99+
    2024-05-15
    c++
  • c++中如何使用类和对象掌握目标
    在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
    99+
    2024-05-15
    c++
  • c++中优先级是什么意思
    c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
    99+
    2024-05-15
    c++
  • c++中a+是什么意思
    c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
    99+
    2024-05-15
    c++
  • c++中a.b什么意思
    c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
    99+
    2024-05-15
    c++
  • C++ 并发编程库的优缺点
    c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
    99+
    2024-05-15
    c++ 并发编程
  • 如何在 Golang 中备份数据库?
    在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
    99+
    2024-05-15
    golang 数据库备份 mysql git 标准库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作