TeradataSQL中的摘要表

TeradataSQL中的摘要表,sql,datetime,pivot,teradata,teradatasql,Sql,Datetime,Pivot,Teradata,Teradatasql,我在Teradata SQL中有下表,称为transactions\u data: User_ID Trans_Date Amount Purchased 3134 2012-08-12 3.35 3135 2012-08-12 4.47 3134 2012-08-13 4.45 我想做的是创建一个表,其中的列覆盖表中的所有日期,行是每个用户一天花费的金额,例如

我在Teradata SQL中有下表,称为transactions\u data:

User_ID      Trans_Date      Amount Purchased
 3134        2012-08-12            3.35
 3135        2012-08-12            4.47
 3134        2012-08-13            4.45
我想做的是创建一个表,其中的列覆盖表中的所有日期,行是每个用户一天花费的金额,例如:

User_ID       2012-08-12      2012-08-13      2012-08-14
 3134            3.35             4.47            0
 3135            4.47               0             0
在Teradata中是否有一种有效的方法来实现这一点,特别是如果总共有365个日期(即,一年的日期还是两年的日期?)


谢谢。

如果您事先知道日期列表,您可以使用条件聚合:

select user_id,
    max(case when trans_date = '2012-08-12' then amount_purchased end) as amount_2012_08_12,
    max(case when trans_date = '2012-08-13' then amount_purchased end) as amount_2012_08_13,
    ...
from mytable
group by user_id
    

由于TD 16也有PIVOT语法,但您仍然需要提前知道日期。