从同一个表中减去两个查询

时间:2015-02-10 01:50:41

标签: sql postgresql aggregate-functions subtraction

假设我有两张桌子: 表device是一组测量设备,表data是由设备测量的一组不同类型的值。

Table data = (no, id,value_type,value, dayhour) no is PK, id refer to table device
Table device = (id, name) id is PK

我目前有一个查询,该查询将获取特定日期value_type生成的特定id的所有值的总和,如:

SELECT SUM(cast(a.value as int)),b.name FROM data a INNER JOIN device b
ON a.id=b.id 
AND a.id=1
AND a.value_type=2
AND date(a.dayhour)='2015-12-12'
GROUP BY b.name

查询可以正常运行。现在我希望能够减去不同值类型的总和。我目前正在做的是两个查询,一个用于获取value_type 2的总和,另一个用于value_type 3的总和,然后在上层过程中进行减法。

但是,我想通过单个查询执行此操作,例如查询将检索一列的总和为value_type 2,另一列的总和为value_type 3和第三一个减去这两列。

1 个答案:

答案 0 :(得分:2)

SELECT b.name, a.*, a.sum2 - a.sum3 AS diff
FROM  (
    SELECT id
         , sum(CASE WHEN value_type = 2 THEN value::int END) AS sum2
         , sum(CASE WHEN value_type = 3 THEN value::int END) AS sum3
    FROM   data
    WHERE  id = 1
    AND    value_type IN (2, 3)
    AND    dayhour >= '2015-12-12 0:0'::timestamp
    AND    dayhour <  '2015-12-13 0:0'::timestamp
    GROUP  BY 1
    ) a
JOIN   device b USING (id);
  • 假设dayhour是数据类型时间戳(缺少信息)。 迄今为止的强制转换将禁用基本索引。这就是我将其转换为sargable谓词的原因。更多细节:
  • 为何选择演员value::int
  • 首先聚合,然后加入设备。便宜。