MySQL中如何求平均值常见实例(AVG函数详解)

2025-11-18 16:50

本文主要是介绍MySQL中如何求平均值常见实例(AVG函数详解),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MySQL中如何求平均值常见实例(AVG函数详解)》MySQLavg()是一个聚合函数,用于返回各种记录中表达式的平均值,:本文主要介绍MySQL中用AVG函数如何求平均值的相关资料,文中通过代...

前言

在使用 mysql 进行数据分析时,计算平均值是最常见的需求之一。MySQL 提供了内置的聚合函数 AVG() 来帮助我们轻松完成这一任务。本文将详细介绍 http://www.chinasem.cnAVG() 函数的使用方法及常见示例。

一、基本语法

SELECT AVG(column_name) FROM table_name;
  • AVG():表示求平均值的聚合函数。
  • column_name:要计算平均值的字段(列名)。
  • table_name:包含该字段的表名。

二、示例讲解

假设我们有一张名为 grades 的表,表结构如下:

idnamecoursescore
1TomMath85
2AliceMath90
3BobEnglish78
4JaneMath95

1. 计算全表平均分

SELECT AVG(score) FROM grades;

输出将是所有记录中 score 字段的平均值。

2. 计算某门课程的平均分(例如:Math)

SELECT AVG(score) FROM grades
WHERE course = 'Math';

输出将是 course 等于 'Math' 的记录中 score 字段的平均值。

三、结合分组统计平均值(GROUP BY)

如果你想分别统计每门课程的平均分,可以使用 GROUP BY

SELECT course, AVG(score) AS average_score
FROM grades
GROUP BY course;

输出结果将是每门课程对应的平均分数。

四、处理空值(NULL)

AVG() 函数在计算时会自动忽略 NULL 值,因此不需要手动筛除:

SELECT AVG(score) FROM grades;
-- NULL 值将被自动排除,不影响平均值

五、小结

  • 使用 AVG() 可以轻松统计列的平均值。
  • 可以搭China编程WHEREGROUP BY 等语句进行更复杂的数据分析。
  • AVG() 会自动忽略 NULL 值,避免错误。

在日常开发中,平均值的统计常用于报表、用户行为分析、商品评分等业务场景,是非常实用的 SQL 技巧

附一个完整示例

假设表结构如下:

CREATE TABLE grades (
    id INT PRIMARY KEY,
    name VARCHAR(50),
    course javascriptVARCHAR(50),
    score DECIMAL(5,2)
);

INSERT INTO grades VALUES 
(1, 'Tom', 'Math', 85.0),
(2, 'Alice', 'Math', 90.0),
(3, 'Bob', 'English', 78.0),
(4, 'Jane', 'Math', 95.0);

查询每门课程的平均分(保留2http://www.chinasem.cn位小数)

SELECT 
    course,
    ROUND(AVG(score), 2) AS average_score
FROM grades
GROUP BY course;

输出结果

course  | average_score
--------|--------------
Math    | 90.00
English | 78.00

到此这篇关于MySQL中如何求平均值的文章就介绍到这了,更多相关MySQL AVG函数求平均值内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.cjavascriptppcns.com)!

这篇关于MySQL中如何求平均值常见实例(AVG函数详解)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1156201

相关文章

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

C++构造函数中explicit详解

《C++构造函数中explicit详解》explicit关键字用于修饰单参数构造函数或可以看作单参数的构造函数,阻止编译器进行隐式类型转换或拷贝初始化,本文就来介绍explicit的使用,感兴趣的可以... 目录1. 什么是explicit2. 隐式转换的问题3.explicit的使用示例基本用法多参数构造