首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何将postgresql中的date_trunc用于将周末天转到下一个工作日?

如何将postgresql中的date_trunc用于将周末天转到下一个工作日?
EN

Database Administration用户
提问于 2016-10-06 23:03:53
回答 1查看 980关注 0票数 1
代码语言:javascript
代码运行次数:0
运行
复制
SELECT DATE_TRUNC('day', trade_date + INTERVAL '1 DAY') from trade_table;

我的日期都是星期一到星期五,但当我date_trunc的日期是星期六(例如平日加1),它是四舍五入到星期六。我想把它四舍五入到下星期一,而不是星期六。我怎么能这么做?

EN

回答 1

Database Administration用户

回答已采纳

发布于 2016-10-07 08:17:52

如果我理解正确,你想添加一天,如果结果是星期六或周日,再加上2或1天,所以结果是下一个工作日。然后提取一周中的第一天(dow)并使用CASE表达式,就可以了:

代码语言:javascript
代码运行次数:0
运行
复制
select date_trunc('day', 
                  trade_date + ( case extract(dow from trade_date)
                                   when 5 THEN 3     -- when Friday, add 3
                                   when 6 THEN 2     -- when Saturday, add 2
                                   else 1            -- any other day, add 1
                                 end
                               ) * interval '1 day' )  
from trade_table ;
票数 0
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/151639

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档