sql中的聚合函数

embedded/2024/11/22 0:52:43/

SQL中的聚合函数用于对表中的数据进行汇总计算,常用来生成统计信息,例如总和、平均值、最大值、最小值等。它们通常与GROUP BY子句一起使用,以对数据分组后再计算聚合结果。

以下是SQL中常用的聚合函数及其详细讲解:


1. COUNT( )

功能: 统计记录的数量。

  • 语法:

    sql

    SELECT COUNT(column_name) FROM table_name;

  • 应用场景:

    • COUNT(*):统计所有行的数量(包括NULL值)。
    • COUNT(column_name):统计指定列中非NULL值的数量。
  • 示例:

     

    sql

    SELECT COUNT(*) AS total_rows FROM employees;

    返回employees表中的总行数。

     

    sql

    SELECT COUNT(department_id) AS valid_departments FROM employees;

    返回department_id列中非NULL值的数量。


2. SUM( )

功能: 计算数值列的总和。

  • 语法:

     

    sql

    SELECT SUM(column_name) FROM table_name;

  • 注意事项:

    • 只能对数值列使用。
    • 如果列中全是NULL,结果为NULL
  • 示例:

     

    sql

    SELECT SUM(salary) AS total_salary FROM employees;

    返回employees表中salary列的总和。

     

    sql

    SELECT department_id, SUM(salary) AS department_salary FROM employees GROUP BY department_id;

    按部门汇总工资。


3. AVG( )

功能: 计算数值列的平均值。

  • 语法:

     

    sql

    SELECT AVG(column_name) FROM table_name;

  • 注意事项:

    • SUM类似,仅适用于数值列。
    • 自动忽略NULL值。
  • 示例:

     

    sql

    SELECT AVG(salary) AS average_salary FROM employees;

    返回员工的平均工资。

     

    sql

    SELECT department_id, AVG(salary) AS average_salary FROM employees GROUP BY department_id;

    按部门计算平均工资。


4. MAX( )

功能: 获取列中的最大值。

  • 语法:

     

    sql

    SELECT MAX(column_name) FROM table_name;

  • 注意事项:

    • 适用于数值、日期和字符串列。
    • 忽略NULL值。
  • 示例:

     

    sql

    SELECT MAX(salary) AS highest_salary FROM employees;

    返回最高工资。

     

    sql

    SELECT MAX(hire_date) AS latest_hire_date FROM employees;

    返回最新的入职日期。


5. MIN( )

功能: 获取列中的最小值。

  • 语法:

     

    sql

    SELECT MIN(column_name) FROM table_name;

  • 注意事项:

    • MAX类似,适用于数值、日期和字符串列。
    • 忽略NULL值。
  • 示例:

     

    sql

    SELECT MIN(salary) AS lowest_salary FROM employees;

    返回最低工资。

     

    sql

    SELECT MIN(hire_date) AS earliest_hire_date FROM employees;

    返回最早的入职日期。


6. GROUP BY 和 聚合函数配合使用

聚合函数常与GROUP BY结合,按分组计算聚合值。

  • 示例:
     

    sql

    SELECT department_id, SUM(salary) AS total_salary FROM employees GROUP BY department_id;

    按部门汇总工资。


7. HAVING 子句

当使用聚合函数筛选分组结果时,需要使用HAVING,而不是WHERE

  • 示例:
     

    sql

    sql">SELECT department_id, SUM(salary) AS total_salary FROM employees GROUP BY department_id HAVING SUM(salary) > 50000;

    SELECT department_id, SUM(salary) AS total_salary FROM employees GROUP BY department_id HAVING SUM(salary) > 50000;

    筛选出工资总和超过50000的部门。


8. 注意事项:

  • 聚合函数忽略NULL值(除了COUNT(*))。
  • 如果在SELECT中使用普通列,必须同时出现在GROUP BY中,否则会报错。


http://www.ppmy.cn/embedded/139475.html

相关文章

STM32编程遇到的问题随笔【一】

STM32编程遇到的问题随笔【一】 一、PB4引脚输出一直为高,无论怎么拉低都不起作用 原因PB4和PB3是复用引脚,用于JTAG调试,芯片是默认开启JTAG功能的,如果我们需要用到这两个引脚,必须降JTAG调试功能关闭,…

C语言和C++的不同

C语言和C都是非常重要的编程语言,它们有着紧密的联系,但也存在显著的差异。以下是对C语言和C的一些主要异同的分析,以及对常用语句的对比。 1. 基本概念与用途 C语言:C语言是一种过程式编程语言,它提供了对低级内存操…

Ubuntu问题 - 显示ubuntu服务器上可用磁盘空间 一条命令df -h

目的 想要放我的 数据集 到新的ubuntu服务器中, 不知道存储空间够不够 开始 使用以下命令直接查看 df -h

【RK3588 Linux 5.x 内核编程】-内核线程

内核线程 文章目录 内核线程1、进程与线程介绍2、线程管理3、内核线程管理函数3.1 创建内核线程3.2 启动内核线程3.3 停止内核线程4、内核线程示例实现4.1 内核线程函数定义4.2 创建和启动内核线程4.3 停止内核线程4.4 完整示例代码5、驱动验证线程是并发处理中使用的编程抽象。…

.NET9 - 新功能体验(一)

被微软形容为“迄今为止最高效、最现代、最安全、最智能、性能最高的.NET版本”——.NET 9已经发布有一周了,今天想和大家一起体验一下新功能。 此次.NET 9在性能、安全性和功能等方面进行了大量改进,包含了数千项的修改,今天主要和大家一起体…

webstorm中 ‘@/**‘报 未安装模块 无法Ctrl定位

接触前端不深 学习中遇到这个问题 记录一下 创建一个名为 jsconfig.json 的文件 内容为以下 { "compilerOptions": {"baseUrl": "./","paths": {"/*": ["src/*"]}},"exclude": ["node_modul…

python读取Oracle库并生成API返回Json格式

一、安装必要的库 首先,确保已经安装了以下库: 有网模式 pip install flask pip install gevent pi install cx_Oracle离线模式: 下载地址:https://pypi.org/simple/flask/ # a. Flask Werkzeug-1.0.1-py2.py3-none-any.whl J…

前端反向代理的配置和實現

反向代理是位於客戶端和服務器之間的一個中間層,它代表客戶端向伺服器發起請求,然後將伺服器的回應返回給客戶端。與傳統的正向代理不同,反向代理是由伺服器端配置的,客戶端通常不知道它的存在。在前端開發中,反向代理…