【问题标题】:Use aggregate function with arithmetic operation将聚合函数与算术运算一起使用
【发布时间】:2017-04-28 16:30:48
【问题描述】:

我有一个有两列的表

这里我需要根据下面的函数找到一条SQL,

Z = accelx-AVG(accelx) for every rows. 

【问题讨论】:

  • 您使用的是什么数据库引擎和版本?你试过什么代码?

标签: sql function aggregate operation


【解决方案1】:

MSSQL Server 上的 TSQL 具有窗口函数。 OVER Clause

SELECT 
    [AccelX]
    ,[AccelX] - AVG([AccelX]) OVER ()
FROM T

【讨论】:

    【解决方案2】:

    这通常使用AVG的解析版本来完成:

    select accelx - avg(accelx) over ()
    from mytable;
    

    【讨论】:

    • 你是对的,但并非所有数据库都有它。我会包括partition by userName
    • 如果我想要每个用户的平均值,我也会这样做。但是,如果那是 OP 想要的,我不会;-)
    【解决方案3】:
    SELECT t1.accelx - t2.avgx as Z, userName 
    FROM TableName as t1
    JOIN (SELECT userName, avg(accelx) as avgx
          FROM TableName
          GROUP BY userName) as t2       
      ON t1.userName = t2.userName
    

    【讨论】:

      【解决方案4】:

      试试这个:

      select t1.accelx - t2.avgx as Z
      from TableName as t1
      inner join (
          select avg(accelx) as avgx
          from TableName
          ) as t2
      on 1 = 1
      

      【讨论】:

      • on 1 = 1?这是一个交叉连接,因此您应该将 inner join 替换为 cross join 并删除虚拟的 on 子句。
      【解决方案5】:

      只需在子查询中计算AVG

      SELECT AccelX - (SELECT AVG(AccelX) FROM T)
      FROM T
      

      【讨论】:

      • 使用窗口函数。 AVG(AccelX) OVER ()
      • @MatthewWhited 不是每个数据库都有它
      猜你喜欢
      • 2014-04-26
      • 2012-12-04
      • 2021-03-24
      • 1970-01-01
      • 1970-01-01
      • 2017-06-05
      • 1970-01-01
      • 2013-11-29
      • 1970-01-01
      相关资源
      最近更新 更多