开发者社区> 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 Server 强制大小写区分方法
1、将数据库中某列强制修改为大小写识别 比如想修改表:tb_TestTable400中的userPWD14列 <span style="font-size:14px;">ALTER TABLE tb_TestTable400 ALTER COLUMN userPWD14 nvarchar(128) COLLATE Chinese_PRC_CS_AS</span&
1260 0
SQL Server 触发器
原文:SQL Server 触发器 触发器是一种特殊类型的存储过程,它不同于之前的我们介绍的存储过程。触发器主要是通过事件进行触发被自动调用执行的。而存储过程可以通过存储过程的名称被调用。 Ø 什么是触发器     触发器对表进行插入、更新、删除的时候会自动执行的特殊存储过程。
621 0
SQL Server触发器
触发器可以做很多事情,但也会带来很多问题。使用它的技巧在于在适当的时候使用,而不要在不适当的时候使用它们。 触发器的一些常见用途如下: 弹性参照完整性:实现很多DRI不能实现的操作(例如,跨数据库或服务器的参照完整性以及很多复杂的关系类型)。 创建神级跟踪:这意味写出的记录不仅跟踪大多数当前的数据,还包括对每个记录进行实际修改的历史数据。随着SQL Server2008中的更改数
1449 0
SQL Server触发器
简单介绍:     触发器其实是一种特殊的存储过程,它只有在特定的事件发生时自动执行。存储过程和触发器都是SQL语句和流程控制语句的集合,存储过程通过存储过程的名字被直接调用,而触发器主要通过时间进行触发而被执行。
767 0
模拟 SQLSERVER 死锁
环境: sqlserver 2008   事务(进程 ID (n))与另一个进程被死锁在锁资源上,并且已被选作死锁牺牲品。请重新运行   死锁原理: 如两个任务 任务1,已经锁定R1,再进行请求R2 任务2,已经锁定R2,再进行请求R1 导致两个任务都进入了阻塞。
1025 0
SQL-SERVER触发器
1、触发器。  定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。  常见的触发器有三种:分别应用于Insert , Update , Delete 事件。
680 0
+关注
waterstar50
码农一名、、
24
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载