【问题标题】:SQL query to exclude some records from the output从输出中排除一些记录的 SQL 查询
【发布时间】:2021-06-24 22:49:16
【问题描述】:

我有一个问题:

SELECT 
       c.device_item_id
     , DATEDIFF(day, (DATE(c.tstmp)), sysdate) AS day
     , (DATE(c.tstmp)) AS date
     , COUNT(c.val) AS count
FROM (
  SELECT 
      b.device_item_id
    , TO_TIMESTAMPTZ(a.tstamp) AT TIME ZONE 'UTC' AS tstmp
    , MAX(a.im_utilization) AS val
    FROM physical_memstats_rate AS a
    INNER JOIN v_poll_item AS b ON a.item_id = b.item_id
    WHERE b.device_item_id IN (
        SELECT item_id
        FROM v_poll_item
        WHERE device_item_id IN (
            SELECT member_item_id
            FROM etl_group_membership
            WHERE group_item_id = 335640
            )
        )
    AND a.tstamp > 1624233600 AND a.tstamp <= 1623801599
    GROUP BY 1, 2 ORDER BY 1, 2 DESC
    ) AS c
WHERE c.val > 48
GROUP BY 1, 2, 3
HAVING COUNT(c.val) > 12
ORDER BY 3, 1 DESC;

这个查询的结果是:

device_item_id | day | date       | count
==========================================
332191         | 7   | 2021-06-17 | 287
298711         | 7   | 2021-06-17 | 104
117722         | 7   | 2021-06-17 | 287
104151         | 7   | 2021-06-17 | 287
5316           | 7   | 2021-06-17 | 287
332191         | 6   | 2021-06-18 | 288
117722         | 6   | 2021-06-18 | 288
104151         | 6   | 2021-06-18 | 288
5316           | 6   | 2021-06-18 | 288
332191         | 5   | 2021-06-19 | 288

我想缩小此结果范围以排除 count(device_item_id)

我尝试使用 EXCEPT,但这让我再次重复整个查询。

请有人建议如何以最简单的方式实现它?

谢谢

【问题讨论】:

  • 更正了我的问题,抱歉。我的意思是包含所有 device_item_ids 如果它们在输出中出现两次以上但选择上面的所有字段。

标签: sql vertica


【解决方案1】:

您可以使用子查询或 CTE:

with t as (
      <your query here>
     )
select t.*
from (select t.*,
             count(*) over (partition by device_item_id) as cnt
      from t
     ) t
where cnt >= 2;

【讨论】:

  • 非常感谢。真的很感激。这很有魅力!!!
猜你喜欢
  • 1970-01-01
  • 2016-11-30
  • 1970-01-01
  • 2011-10-02
  • 1970-01-01
  • 2015-12-10
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多