首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >oracle pl/sql:排除周末的datepart ()函数

oracle pl/sql:排除周末的datepart ()函数
EN

Stack Overflow用户
提问于 2011-07-02 04:55:12
回答 1查看 1.2K关注 0票数 0

是否可以使用to_number(to_char())函数从一系列日期中排除所有周末?

例如,在我的表中有两个日期列,比如start和finish (格式为'06/06/2011 10:00:00 am'),我想估计finish-start的持续时间,不包括周六和周日。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-07-05 23:25:07

如果我理解正确的话,您想要计算两个日期之间的差异,但从结果范围中排除每个周末的2天。对吗?

如果这是您想要的,下面的代码应该在以下假设下工作:

  • 我假设开始和结束不在周末。
  • 我不验证结束是否在开始之前。

基本上,这只是一个计算出日期范围内有多少个周末的问题。所以很明显每7天就有一个周末。然后我们只需检查该范围是否围绕一个周末,如果是,则再添加一个。

代码语言:javascript
运行
复制
FUNCION dateDiff( dt_start DATE, dt_end DATE ) RETURN NUMBER
IS
    raw_diff NUMBER;
    weekends NUMBER;
BEGIN
    raw_diff := dt_end - dt_start;
    weekends := TRUNC( raw_diff / 7 );
    IF( ( dt_start - TRUNC( dt_start, 'DAY' ) )
      > ( dt_end   - TRUNC( dt_end  , 'DAY' ) ) )
    THEN
        weekends := weekends + 1;
    END IF;
    RETURN raw_diff - ( weekends * 2 );
END;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6553140

复制
相关文章

相似问题

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