SQL自学:什么是SQL的聚集函数,如何利用它们汇总表的数据

embedded/2024/10/10 21:57:27/

在 SQL(Structured Query Language,结构化查询语言)中,聚集函数也称为聚合函数,是对一组值进行计算并返回单一值的函数。

一、常见的聚集函数及功能

 1. AVG():用于计算某一列的平均值

例如,在一个包含学生成绩表的数据库中,可以使用 AVG(score)来计算学生成绩的平均分。

2. SUM():计算某一列数值的总和

比如在销售数据表中,可以用 SUM(sales_amount)来计算总销售额。

3. COUNT():统计某一列中值的数量或者统计行数

COUNT(*)统计所有的行数,而 COUNT(column_name)统计特定列中不为 NULL的值的数量。

4. MAX():返回某一列中的最大值。

例如在产品价格表中,可以用 MAX(price)找出最贵的产品价格。

5. MIN():返回某一列中的最小值

如同在温度记录表中,使用 MIN(temperature)找出最低温度。


二、以下是对 SQL 中聚集函数注意事项的详细例子:

(一)聚集函数与 GROUP BY 子句结合使用

假设有一个员工表 employees,包含字段 employee_id(员工编号)、department(部门)、salary(工资)。

sql">SELECT department, AVG(salary) AS avg_salary
FROM employees GROUP BY department; 

这个查询将按照部门对员工进行分组,并计算每个部门的平均工资。例如,可能有部门“销售部”“研发部”“财务部”等,查询结果会显示每个部门的名称以及该部门员工的平均工资。

(二)聚集函数对数值类型列的计算

1. 对于数值类型列,聚集函数能正常工作。

 假设员工表中有一列 age(年龄)是数值类型,使用 AVG(age)可以计算出员工的平均年龄。 使用 SUM(age)可以计算出所有员工年龄总和,但这个在实际场景中可能意义不大。

2. 对于非数值类型列使用聚集函数可能出现问题。 

假设员工表中有一列 name(员工姓名)是字符类型,如果尝试使用 AVG(name)或 SUM(name),数据库会返回错误,因为这些聚集函数不能对字符类型进行数学运算。

(三)聚集函数对 NULL 值的处理

 1. COUNT(*): 假设员工表中有一行数据中某些字段值缺失,即存在 NULL值。使用 COUNT(*) 会统计包含 NULL值的行。

例如,如果有 10 行数据,即使其中某些行的部分字段为 NULL,COUNT(*)的结果仍然是 10。

2. AVG() 和 SUM(): 假设有一个销售表 sales,包含字段 sale_id(销售编号)、amount(销售金额)和 bonus(奖金)。如果某些行的 bonus 字段为 NULL。 当使用 SUM(bonus)计算奖金总和时,那些 bonus为 NULL 的行将被忽略。如果有 5 行数据,其中 3 行的 bonus 分别为 100、200、300,另外 2 行的 bonus 为 NULL,那么 SUM(bonus)的结果为 100 + 200 + 300 = 600。  对于 AVG(bonus),计算平均奖金时同样会忽略 NULL值。

假设上述例子中使用 AVG(bonus),结果为 600 / 3 = 200。

练习

1.编写SQL语句,确定已售出产品的总数(使用OrderItems中的quantity列)​。

2.修改刚刚创建的语句,确定已售出产品项(prod_item)BR01的总数。

3.编写SQL语句,确定Products表中价格不超过10美元的最贵产品的价格(prod_price)​。将计算所得的字段命名为max_price。


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

相关文章

自动驾驶汽车横向控制方法研究综述

【摘要】 为实现精确、稳定的横向控制,提高车辆自主行驶的安全性和保障乘坐舒适性,综述了近年来自动驾驶汽车横向控制方法的最新进展,包括经典控制方法和基于深度学习的方法,讨论了各类方法的性能特点及在应用中的优缺点&#xff…

开发常用编辑器,你知道几个?

以下是 Python 最受欢迎的 10 个编辑器: pyCharm 由捷克公司 JetBrains 开发,是使用最广泛的 Python IDE 之一。它分为社区版和专业版,社区版免费且功能足够满足日常基本需求,专业版功能更强大但需付费。 优势在于智能代码补全、…

2024年最佳平替电容笔对比:西圣、摩米士、倍思,哪款更适合你?

作为一位专注于数码产品的博主,我深知近年来平替电容笔在消费者中的热度不断攀升。这种电容笔以其亲民的价格和卓越的书写体验引起了广泛关注,尤其适合那些需要用iPad学习和办公的无纸化爱好者。 西圣这款自带充电仓的电容笔备受关注,尤其因…

【PostgreSQL】实战篇——用户管理、角色和权限控制的高级用法及技巧

数据库中用户管理、角色和权限控制不仅仅是基础的安全措施,更是实现复杂应用需求和优化数据库性能的重要手段。 通过深入理解这些概念,数据库管理员可以更有效地管理用户访问、确保数据安全,并优化系统性能。以下是对这些概念的详细介绍以及…

vue3的知识整理

1. vue3的生命周期 vue3的生命周期一般有2种形式写法,一种是基于vue2的options API的写法,一种是vue3特有的Composition API options API的生命周期 基本同vue2的生命周期基础,只是为了与生命周期beforeCreate和created对应,将bef…

VScode连接远程服务器踩坑实战(新版离线vscode-server安装)

想要用VScode连接远程服务器,但远程服务器并没有连接外网,因此需要离线手动安装vscode-server但网上的方法都是旧版本的安装,没有新版本的配置。因此记录一下我都踩坑实战。 1、VScode扩展安装与配置 (1)vscode扩展安…

微信小程序——音乐播放器

一、界面设计 播放页面: 显示当前播放歌曲的封面图片、歌曲名称、歌手名称。有播放 / 暂停按钮、上一首、下一首按钮。进度条显示播放进度,可以拖动进度条调整播放位置。音量调节滑块。 歌曲列表页面: 展示歌曲列表,包括歌曲名称、…

Vue.js 中<teleport> 组件,<Suspense> 组件

一、&#xff1c;teleport&#xff1e; 组件 在 Vue.js 中&#xff0c;<teleport> 是一个非常强大的内置组件&#xff0c;用于将子组件或元素“传送”到 DOM 中的不同位置&#xff0c;而不仅限于它们在父组件中的结构。这可以帮助解决许多布局和样式方面的问题&…