我想为数据记录制作一个标签,列出年份和季度,例如 2014-Q2。
在 SQL 中,我可以通过以下方式完成此任务:
SELECT VARCHAR(YEAR_) CONCAT '-Q' CONCAT(CAST(CEILING(CAST(MONTH_) AS
DECIMAL(4, 2)) / 3) AS CHAR(1))) AS QTR_ FROM TABLE
我试图在 DataStage (v 8.5) 的变压器阶段收集相同的结果,我认为以下粗略推导会起作用:
If
(Link.MONTH_ =< 3)
Then (Link.YEAR_ : '-Q1')
Else
(If
(Link.MONTH_ > 3 and Link.MONTH_ =< 6)
Then (Link.YEAR_ : '-Q2')
Else
(If
(Link.MONTH_ > 6 and Link.MONTH_ =< 9)
Then (Link.YEAR_ : '-Q3')
Else
('Y' : DSLink2.YEAR : '-Q4')
)
)
也许变压器级不是最好的选择,欢迎所有建议,因为现在推导会出错。