开发者社区> waterstar50> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

Sql Server 指定列的乘积

简介: 需要统计指定列的乘积 SQL SERVER中有EXP(SUM(LOG(字段)))的函数 如下例子: SELECT WorkOrder , LineId , ...
+关注继续查看

需要统计指定列的乘积
SQL SERVER中有EXP(SUM(LOG(字段)))的函数
如下例子:

SELECT    WorkOrder ,
          LineId ,
          ROUND(EXP(SUM(LOG(ThroughRate))), 4) * 100 AS ThroughRate
          FROM   #ThroughRate
          GROUP BY  WorkOrder ,
                    LineId

EXP(SUM(LOG(字段))) 字段的值是不能够包含0的,否则出现无效浮点数操作的错误
其实如果指定列含有0的话,最终的乘积是0;所以考虑把结果集分成两部分,等于0以及不等于0两种情况计算,最终在合并查询处理

 SELECT  m.WorkOrder ,
                m.LineId ,
                CASE WHEN n.ThroughRate = 0 THEN 0
                     ELSE CONVERT(DECIMAL(18, 4), m.ThroughRate)
                END AS ThroughRate
        FROM    ( SELECT    WorkOrder ,
                            LineId ,
                            ROUND(EXP(SUM(LOG(ThroughRate))), 4) * 100 AS ThroughRate
                  FROM      #ThroughRate
                  WHERE     ThroughRate != 0
                  GROUP BY  WorkOrder ,
                            LineId
                ) m
                LEFT JOIN ( SELECT  WorkOrder ,
                                    LineId ,
                                    ThroughRate
                            FROM    #ThroughRate
                            WHERE   ThroughRate = 0
                            GROUP BY WorkOrder ,
                                    LineId ,
                                    ThroughRate
                          ) n ON m.WorkOrder = n.WorkOrder
                                 AND m.LineId = n.LineId 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
sql 增加列
alter table student add nickname char(20)
507 0
T-SQL查询:语句执行顺序
原文:T-SQL查询:语句执行顺序 读书笔记:《Microsoft SQL Server 2008技术内幕:T-SQL查询》   ===============  T-SQL查询的执行顺序 ===============      =============== T-SQL查询的示意图...
789 0
+关注
waterstar50
码农一名、、
24
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载