日期计算在 Oracle SQL 案例陈述中不起作用?

Date calculation not working in Oracle SQL Case Statement?

我正在尝试将数据集的一周开始时间从星期一更改为上周五。整体数据将聚合到一周级别,如下所示。

第 1 周

星期五, 周六, 星期日, 周一, 周二, 周三, 周四

我想出的最好的方法是将星期五、星期六和星期日设置为下一周的第一天(系统第一天是星期一,最后一天是星期日)的案例语句。

SELECT TRANSACTIONDATE,
        CASE  
        WHEN TO_CHAR(TRANSACTIONDATE, 'DAY') IN ('FRIDAY', 'SATURDAY', 
'SUNDAY') THEN (TRUNC(TRANSACTIONDATE, 'IW')+7)
        ELSE TRUNC(TRANSACTIONDATE, 'IW')
        END AS TEST
FROM TRANSACTIONS

我对这段代码的逻辑是:如果是 Fri、Sat 或 Sun,则找到一周的第一天,然后加 7 返回下周的一周的第一天。

问题是语句 "TRUNC(TRANSACTIONDATE, 'IW')+7" 没有将 7 天添加到一周的开始。

当我查询时

select "TRUNC(TRANSACTIONDATE, 'IW')+7" from transactions 

我知道下周的开始是正确的。

这样从周五到周四的所有日子都在同一周数下。

知道哪里出了问题,或者是否有更好的方法来完成我所追求的目标?

谢谢, 汤姆

编辑**

第一个数据集是我想要实现的,

Date           Day       Week
4/1/2018       Monday    1
4/2/2018       Tuesday   1
4/3/2018       Wednesday 1
4/4/2018       Thursday  1
4/5/2018       Friday    2
4/6/2018       Saturday  2
4/7/2018       Sunday    2
4/8/2018       Monday    2
4/9/2018       Tuesday   2
4/10/2018      Wednesday 2
4/11/2018      Thursday  2

所以上面你可以看到我希望 Firday/Saturday/Sunday 进入下周。

这是当前系统dates/weeks所做的,

Date        Day      Week
4/1/2018    Monday    1
4/2/2018    Tuesday   1
4/3/2018    Wednesday 1
4/4/2018    Thursday  1
4/5/2018    Friday    1
4/6/2018    Saturday  1
4/7/2018    Sunday    1
4/8/2018    Monday    2
4/9/2018    Tuesday   2

问题是TO_CHAR(TRANSACTIONDATE, 'DAY')

  • 当您使用 'DAY' 时,工作日名称将用 space 个字符填充。试试SELECT '<'||TO_CHAR(DATE '2018-05-07', 'DAY')||'>' from dual;看看效果

  • 功能TO_CHAR(..., 'DAY')returns星期名称根据当前用户会话NLS_DATE_LANGUAGE设置。这可能是英语也可能不是英语。

将您的表达式更改为

TO_CHAR(TRANSACTIONDATE, 'fmDAY', 'NLS_DATE_LANGUAGE=american') IN ('FRIDAY', 'SATURDAY', 'SUNDAY')