mysql 聚合乘法_SQL中的乘法聚合运算符

本文探讨了在SQL中如何实现类似乘法的聚合运算,特别是在MySQL中的实现方式。通过示例展示了如何使用EXP和LOG函数来计算多个数值的乘积,同时处理了负数和零的情况。此外,还提供了在SQL Server中处理负数和零的策略。
摘要由CSDN通过智能技术生成

MUL是指值的渐进乘法?

即使有100个较小的行(例如10s),您的MUL(列)也会溢出任何数据类型!由于滥用/滥用的可能性很高,并且使用范围非常有限,因此不必成为SQL标准。正如其他人所展示的那样,有许多数学方法可以解决该问题,就像有很多方法可以使用标准(和通用)方法在SQL中进行棘手的计算一样。

样本数据:

Column

1

2

4

8

COUNT : 4 items (1 for each non-null)

SUM   : 1 + 2 + 4 + 8 = 15

AVG   : 3.75 (SUM/COUNT)

MUL   : 1 x 2 x 4 x 8 ? ( =64 )

为了完整起见,Oracle,MSSQL,MySQL核心实现*

Oracle : EXP(SUM(LN(column)))   or  POWER(N,SUM(LOG(column, N)))

MSSQL  : EXP(SUM(LOG(column)))  or  POWER(N,SUM(LOG(column)/LOG(N)))

MySQL  : EXP(SUM(LOG(column)))  or  POW(N,SUM(LOG(N,column)))

注意在SQL Server中使用EXP / LOG时,请注意返回类型http://msdn.microsoft.com/zh-cn/library/ms187592.aspx

POWER表单允许使用更大的数字(使用比Euler的数字大的基数),并且如果结果增长太大而无法使用POWER将其返回,则可以只返回对数值并在SQL查询之外计算实际数字</

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值