mysql中sum()函数如何用

mysql中,sum()函数用于计算一组值或表达式的总和,语法为“SUM(DISTINCT expression)”,DISTINCT运算符允许计算集合中的不同值。sum()函数需要配合SELECT语句一起使用,如果在没有返回匹配行SELECT语句中使用SUM()函数,则SUM()函数会返回NULL,而不是0;SUM()函数在计算时,会忽略列值为NULL的行。

mysql中sum()函数如何用

本教程操作环境:windows7系统、mysql8版本、Dell G3电脑。

mysql sum()函数

SUM()函数用于计算一组值或表达式的总和,SUM()函数的语法如下:

SUM(DISTINCT expression)
参数 描述
expression 必须项。字段或公式

SUM()函数是如何工作的?

  • 如果在没有返回匹配行SELECT语句中使用SUM函数,则SUM函数返回NULL,而不是0。

  • DISTINCT运算符允许计算集合中的不同值。

  • SUM()函数在计算时,会忽略列值为NULL的行。

sum()函数的使用示例

为了方便理解,首先创建一个学生成绩表 tb_students_score,学生成绩表的数据内容如下所示

mysql> SELECT * FROM tb_students_score;

mysql中sum()函数如何用

使用sum()函数在 tb_students_score 表中计算学生成绩的总分

mysql> SELECT SUM(student_score) AS score_sum FROM tb_students_score;

mysql中sum()函数如何用

由查询结果可以看到,SUM() 函数返回学生的所有成绩之和为 942。

扩展知识:

MySQL SUM与GROUP BY子句

当与GROUP BY子句组合时,SUM()函数计算GROUP BY子句中指定的每个分组的总和。例如,可以使用具有GROUP BY子句的SUM函数计算每个订单的总金额,如下所示:

SELECT orderNumber,       FORMAT(SUM(quantityOrdered * priceEach),2) totalFROM orderdetailsGROUP BY orderNumberORDER BY SUM(quantityOrdered * priceEach) DESC;

执行上面查询语句,得到以下结果 –

+-------------+-----------+| orderNumber | total     |+-------------+-----------+|       10165 | 67,392.85 ||       10287 | 61,402.00 ||       10310 | 61,234.67 ||       10212 | 59,830.55 |*** 此处省略了一大波数据 *****|       10116 | 1,627.56  ||       10158 | 1,491.38  ||       10144 | 1,128.20  ||       10408 | 615.45    |+-------------+-----------+327 rows in set

MySQL SUM与HAVING

您可以使用HAVING子句中在SUM函数中来根据特定条件过滤结果。例如,您可以计算总订单量,只能选择总金额大于60000的订单。如下查询语句 –

SELECT orderNumber,       FORMAT(SUM(quantityOrdered * priceEach),2)FROM orderdetailsGROUP BY orderNumberHAVING SUM(quantityOrdered * priceEach) > 60000ORDER BY SUM(quantityOrdered * priceEach);

执行上面查询语句,得到以下结果 –

mysql中sum()函数如何用

MySQL SUM与LIMIT

假设您想要计算products表中前十名最昂贵的产品的总和,可以提出以下查询:

SELECT SUM(buyprice)FROM productsORDER BY buyprice DESCLIMIT 10;

执行上面查询语句,得到以下结果 –

mysql中sum()函数如何用

它不起作用,因为具有SUM函数的SELECT语句只返回一行,LIMIT子句约束要返回的行数无效。要解决此问题,请使用以下子查询:

SELECT FORMAT(SUM(buyprice),2) FROM(SELECT buypriceFROM productsORDER BY buyprice DESCLIMIT 10) price;

执行上面查询语句,得到以下结果 –

mysql中sum()函数如何用

上面语句是怎么运行的?子查询选择十大价格较高的产品。外部查询计算从子查询返回的前10个价格较高的产品的总和。

MySQL SUM与NULL

如果没有匹配的行,则SUM函数返回NULL值。 有时,您希望SUM函数返回0而不是NULL。 在这种情况下,可以使用COALESCE函数。COALESCE函数接受两个参数,如果名列前茅个参数为NULL,则返回第二个参数,否则返回名列前茅个参数; 参考以下查询语句:

SELECT COALESCE(SUM(quantityOrdered * priceEach),0)FROM orderdetailsWHERE productCode = 'S1_212121';

执行上面查询语句,得到以下结果 –

mysql中sum()函数如何用

到此,相信大家对“mysql中sum()函数如何用”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

文章标题:mysql中sum()函数如何用,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/29846

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
亿速云的头像亿速云认证作者
上一篇 2022年9月26日 上午1:49
下一篇 2022年9月26日 上午1:50

相关推荐

  • Vue 是如何实现的数据响应式

    vue 是一个易上手的框架,许多便捷功能都在其内部做了集成,其中最有区别性的功能就是其潜藏于底层的响应式系统。组件状态都是响应式的 JavaScript 对象。当更改它们时,视图会随即更新,这让状态管理更加简单直观。那么,Vue 响应性系统是如何实现的呢?本文也是在阅读了 Vue 源码后的理解以及模…

    2022年9月16日
    42600
  • 如何利用SAP ASE安全漏洞入侵数据库服务器

    SAP公司的Sybase数据库软件中存在一系列新的严重漏洞,没有权限的攻击者可利用这些漏洞完全控制目标数据库,在某些场景中,甚至可完全控制底层操作系统。 网络安全公司Trustware发现的这六个安全漏洞存在于Sybase Adaptive Server Enterprise(ASE)中,Sybas…

    2022年9月16日
    43100
  • 如何深度分析Nazar 组件

    6:22 AM 11/7/2012 conficker still on target 6:18 AM 11/7/2012 checking logs – we are clean 8:16 PM 7/2/2012 – BOOM!, got the callback 这些是方…

    2022年9月15日
    42000
  • PDF转Word SDK效果对比

    Hello 大家好,我是小瘪三。我们打工人平时办公免不了要对一些文档格式行转换。我们将探讨几款主流的 PDF 转 Word SDK,分析它们在我们打工人的实际工作中所呈现的优势与劣势。 Solid:老牌的 PDF to Office 转档库,有几十年的积累。 Aspose: 支持非常多的文件格式互转…

    2023年8月31日
    28800
  • vue怎么实现大文件分片上传与断点续传送

    今天分享文章“vue怎么实现大文件分片上传与断点续传送”,主要从:问题、探索过程、解决方案、功能介绍等几个方面为大家介绍,希望能帮到您。 问题: 前段时间做视频上传业务,通过网页上传视频到服务器。 视频大小 小则几十M,大则 1G+,以一般的HTTP请求发送数据的方式的话,会遇到的问题: 1、文件过…

    2022年6月29日
    89900
  • 怎么用vlookup函数完成图书名称自动填充

    vlookup函数完成图书名称自动填充的方法 名列前茅步,在需要填充的位置输入“=vlookup()” 第二步,选中你依据的查找项目,这里我们选择“图书编号” 第三步,进入编号对照表格,框选需要查找的区域,这里我们选择图书编号和图书名称这两栏。 第四步,查看需要填充的内容列数,这里是2就输入2。 第…

    2022年9月22日
    68700
  • mysql5.7.12如何修改用户密码

    本教程操作环境:windows7系统、mysql5.7.12版本、Dell G3电脑。 在mysql中,可以登录root账号,利用root修改普通用户密码。 root 用户拥有很高的权限,不仅可以修改自己的密码,还可以修改其他用户的密码。 mysql5.7.12修改用户密码的步骤 1、使用“win+…

    2022年9月19日
    56100
  • mysql函数的作用有哪些

    mysql函数的作用是用来实现某些功能运算和完成各种特定操作;使用函数能够允许标准组件式编程,提高了SQL语句的重用性、共享性和可移植性,可以减少重复编写程序段的工作量,提高程序的可读性,提高程序编译和运行效率,产生质量较高的目标代码。 本教程操作环境:windows10系统、mysql8.0.22…

    2022年9月6日
    48600
  • css语言中漂浮的语法是什么

    css语言中的漂浮语法为“float:属性值;”。float属性用于定义元素在哪个方向浮动,会让盒子(元素)漂浮在标准流的上面,其周围的元素也会重新排列,直到它的外边缘碰到包含框或另一个浮动框的边框为止。该属性有三个属性值:1、“left”,定义元素向左浮动;2、“right”,定义元素向右浮动;3…

    2022年9月22日
    49300
  • C语言数据结构之栈与队列怎么相互实现

    一、用对列实现栈 题干要求: 细节分析:队列是先进先出; 要实现的栈是先进后出。 解题思路:假设:先用一个队列储存数据 N 个,然后将前 N-1 个数据导入到另一个队列, 此时,原始队列中仅剩一个,是最后剩的数据,便可将其导出,这便是一次后进先出。 细节点:每次导出数据时,都需要一个队列向另一个队列…

    2022年9月21日
    35900
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部