mysql sum DISTINCT 思路就是把id弄成小数点,使所有值变成唯一

-- 思路就是把id弄成小数点,使所有值变成唯一
-- 值很大的情况可能不适用,我的数据较小


cast( -- cast开始


( -- 计算开始

(

sum(DISTINCT concat(replace(cast(price * 100 as CHAR),'.00',''), '.', id))

-

sum(DISTINCT concat('0.', id))

) / 100


) -- 计算结束

 as DECIMAL(9,2)) -- cast结束

 as amount

 

引用\[1\]中提到,sum()函数返回表达式的总和。如果返回集合没有行,则sum()函数返回null。distinct关键字可以用于只对表达式的不同求和。引用\[2\]中给出了sum(\[DISTINCT\] expr)函数的示例用法,它用于计算数型列的总和,并忽略null。引用\[3\]中提到,sum函数是在MySQL中经常使用的函数之一,用于统计满足条件的行中指定列的总和。在MySQL查询中,可以通过几个小案例来深入了解sum函数的使用,并在查询中进行优化。 问题: MySQL中的sum(distinct)函数是用来做什么的? 回答: 在MySQL中,sum(distinct)函数用于计算指定列的不同的总和。它可以忽略重复的,只计算不同的总和。这在需要对某一列的不同进行求和时非常有用。 #### 引用[.reference_title] - *1* *3* [MySQL中的sum函数用法实例详解](https://blog.csdn.net/Hsuesh/article/details/115269983)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [16、MySQL基础之聚合函数](https://blog.csdn.net/weixin_43007659/article/details/105025968)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值