首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >计算列上的STDEV

计算列上的STDEV
EN

Stack Overflow用户
提问于 2015-04-22 15:50:20
回答 1查看 119关注 0票数 1

因此,我有两个列,我想在上面做一个除法,然后我想对结果的列执行一个stdev,我尝试了下面的sql,但是它不能工作,我还没有找到如何将内部select保存为一个变量,然后在这个var上执行stdev。我撞错树了吗?有什么想法吗?

代码语言:javascript
复制
select 
stdev(
  select 
       convert(decimal(20,5),convert(decimal(20,5),(s.received))
        /convert(decimal(20,5),(s.sent)))*100 as DDR 
        from someTable s 
        where s.SomethingName = 'thisthingsName' 
        and s.Date like '2015-04-16%'
)
from someTable
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-04-22 15:53:45

代码语言:javascript
复制
select 
    stdev(
        convert(decimal(20,5),convert(decimal(20,5),(s.received))
        / convert(decimal(20,5),(s.sent)))*100  
    ) as deviation
from 
    someTable s
where
    s.SomethingName = 'thisthingsName' 
    and s.Date like '2015-04-16%'

请注意,如果您的Server版本是2008或更高版本,您也可以这样做

代码语言:javascript
复制
and cast(s.Date as date) = '2015-04-16'

在Server 2012中,您可以这样做

代码语言:javascript
复制
and cast(s.Date as date) = DATEFROMPARTS(2015,04,16)

而不是(不精确!)日期字段上的字符串比较。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29802749

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档