CASE声明未提供所需答案

时间:2017-06-14 20:36:01

标签: sql date case teradata between

我有一个非常大的表格,显示产品和事件类型的每日记录。我愿意重新排列下面的查询方式,但认为case语句会为我提供必要的输出。

TABLE_1:

DATES      PRODUCT  EVENT
5/20/2017   APPLE   SALE
5/21/2017   APPLE   SALE
5/22/2017   APPLE   SALE
5/23/2017   APPLE   SALE
5/24/2017   APPLE   SALE
5/25/2017   APPLE   SALE
5/26/2017   APPLE   SALE
5/27/2017   APPLE   FULL PRICE
5/28/2017   APPLE   FULL PRICE
5/29/2017   APPLE   FULL PRICE
5/30/2017   APPLE   FULL PRICE
5/31/2017   APPLE   FULL PRICE
6/1/2017    APPLE   FULL PRICE
6/2/2017    APPLE   FULL PRICE
6/3/2017    APPLE   FULL PRICE
6/4/2017    APPLE   FULL PRICE
6/5/2017    APPLE   FULL PRICE
6/6/2017    APPLE   FULL PRICE
6/7/2017    APPLE   LIQUIDATION
6/8/2017    APPLE   LIQUIDATION
6/9/2017    APPLE   LIQUIDATION
6/10/2017   APPLE   LIQUIDATION
6/11/2017   APPLE   LIQUIDATION
6/12/2017   APPLE   LIQUIDATION
6/13/2017   APPLE   LIQUIDATION
6/14/2017   APPLE   LIQUIDATION
5/20/2017   BANANA  SALE
5/21/2017   BANANA  SALE
5/22/2017   BANANA  SALE
5/23/2017   BANANA  SALE
5/24/2017   BANANA  SALE
5/25/2017   BANANA  SALE
5/26/2017   BANANA  SALE
5/27/2017   BANANA  SALE
5/28/2017   BANANA  SALE
5/29/2017   BANANA  SALE
5/30/2017   BANANA  FULL PRICE
5/31/2017   BANANA  FULL PRICE
6/1/2017    BANANA  FULL PRICE
6/2/2017    BANANA  FULL PRICE
6/3/2017    BANANA  FULL PRICE
6/4/2017    BANANA  FULL PRICE
6/5/2017    BANANA  FULL PRICE
6/6/2017    BANANA  FULL PRICE
6/7/2017    BANANA  FULL PRICE
6/8/2017    BANANA  FULL PRICE
6/9/2017    BANANA  FULL PRICE
6/10/2017   BANANA  FULL PRICE
6/11/2017   BANANA  FULL PRICE
6/12/2017   BANANA  FULL PRICE
6/13/2017   BANANA  FULL PRICE
6/14/2017   BANANA  FULL PRICE

当前查询:

select
    product,
    case when event in ('liquidation') then 'yes' else 'no' end LIQ,
    count(dates) as days
FROM TABLE_1
where dates between '5/20/2017' and '6/14/2017'
group by
    product

如果在日期范围内处于清算状态,我希望按产品记录单一记录,是/否。此查询将执行,但会提供以下结果:

PRODUCT   LIQ         DAYS
APPLE     NO           18
APPLE     YES           8
BANANA    NO           26

如果产品在2017年5月20日至2017年6月14日期间清算,我正在寻找一个简单的是或否。这就是我要找的东西:

PRODUCT    LIQ        DAYS
APPLE      YES         26
BANANA     NO          26

谢谢!

1 个答案:

答案 0 :(得分:1)

以下使用"是"的属性和"不"那是"是" > "无":

select product,
       max(case when event in ('liquidation') then 'yes' else 'no' end) as LIQ,
       count(dates) as days
from TABLE_1
where dates between '2017-05-20' and '2017-06-14'
group by product;