服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - mysql sum(if())和count(if())的用法说明

mysql sum(if())和count(if())的用法说明

2022-09-02 14:48cindyCode Mysql

这篇文章主要介绍了mysql sum(if())和count(if())的用法说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

mysql sum(if())和count(if())的用法

?
1
SELECT SUM(if(category=1,size,0)) ,COUNT(if(category=1,true,null)) FORM t_file;

解析

?
1
sum(if(category=1,size,0))

sum函数返回一个值类型的数值,如果category=1,则返回size,如果category不等于1就返回0。

?
1
count(if(category=1,true,null))

count函数返回一个布尔值类型的数值,如果category=1,返回true,如果category不等于1返回null,如果写成count(If(category=1,1,0) 则返回的全是true,也就是说全都会计数,而count()间断内容是true还是null,如果不是null就计数,如果是null就不计数。

所以count(if())的写法应该是count(if(表达式表达式,true,null)); 

mysql 聚合函数 根据条件求和 sum(if())

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
SELECT
    p.Id Id,
    p.ImgUrl ImgUrl,
    p.Title Title,
    p.ReferOutPrice ReferOutPrice,
    e.`Status`,
    SUM(IF(e.`Status`=1 OR e.`Status`=2, ed.Number,0))
FROM
    Product p
    LEFT JOIN EBOrdersDetails ed ON p.id = ed.ProductId
    LEFT JOIN EBOrders e ON ed.PurchaseNo = e.PurchaseNo
WHERE
    p.StoreId = 143
    AND p.`Status` >-1
  GROUP BY p.Id

mysql sum(if())和count(if())的用法说明

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/q812002440/article/details/76898619

延伸 · 阅读

精彩推荐