得出一个月有多少工作日

原创 2004年06月30日 21:10:00

procedure gzr(v_nowdate in varchar2) as? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
v_firstsaturday varchar2(10);? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???
v_outdate date;? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
v_countworkday number(10);? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???
begin? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???
? ? ? ? ? ? select to_char(next_day(to_date(concat(v_nowdate,'01'),'yyyymmdd'),1)-1,'dd')? ?? ?? ?? ?? ?? ?
??? ? ? ? into v_firstsaturday? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???
??? ? ? ? from sys.dual;? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???
??v_countworkday:=to_number(v_firstsaturday)-1;? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???
??loop? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
? ? v_outdate:=to_date(concat(v_nowdate,v_firstsaturday+7),'yyyymmdd');? ?? ?? ?? ?? ?? ?? ?? ?? ???
? ? if??v_outdate yyymm'),'01'),'yyyymmdd') then? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
? ?? ?v_countworkday:=v_countworkday+5;? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
? ?? ?else? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
? ?? ?v_countworkday:=v_countworkday+5-to_number(v_outdate-to_date(concat(to_char(add_months(sysdate
,1),'yyyymm'),'01'),'yyyymmdd'));? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
? ? end if;? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???
??exit when v_outdate>=to_date(concat(to_char(add_months(sysdate,1),'yyyymm'),'01'),'yyyymmdd');? ?

TEXT? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
----------------------------------------------------------------------------------------------------
??end loop;? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ???
??dbms_output.put_line(v_countworkday);? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?
end gzr;

方法二:

CREATE OR REPLACE FUNCTION Get_WorkingDays(
??ny IN VARCHAR2
) RETURN INTEGER IS
/*------------------------------------------------------------------------------------------
函数名称:Get_WorkingDays
中文名称:求某一年月中共有多少工作日
作者姓名: XINGPING
编写时间: 2004-05-22
输入参数:NY:所求包含工作日数的年月,格式为yyyymm,如200405
返 回 值:整型值,包含的工作日数目。
算法描述:
? ? 1).列举出参数给出的年月中的每一天。这里使用了一个表(ljrq是我的库中的一张表。这个表可以是有权访问的、记录条数至少为31的任意一张表或视图)来构造出某年月的每一天。
? ? 2).用这些日期和一个已知星期几的日期相减(2001-12-30是星期天),所得的差再对7求模。如果所求年月在2001-12-30以前,那么所得的差既是负数,求模后所得值范围为大于-6,小于0,如-1表示星期六,故先将求模的结果加7,再求7的模.
? ? 3).过滤掉结果集中值为0和6的元素,然后求count,所得即为工作日数目。? ?? ?
-------------------------------------------------------------------------------------------------*/
??Result INTEGER;
BEGIN
??SELECT COUNT(*) INTO Result
? ? FROM (SELECT MOD(MOD(q.rq-to_date('2001-12-30','yyyy-mm-dd'),7),7) weekday
? ?? ?? ?? ?FROM ( SELECT to_date(ny||t.dd,'yyyymmdd') rq
? ?? ?? ?? ?? ?? ?? ?FROM (SELECT substr(100+ROWNUM,2,2) dd
? ?? ?? ?? ?? ?? ?? ?? ?? ???FROM ljrq z WHERE Rownum<=31
? ?? ?? ?? ?? ?? ?? ?? ???) t
? ?? ?? ?? ?? ?? ?? ?WHERE to_date(ny||t.dd,'yyyymmdd')
? ?? ?? ?? ?? ?? ?? ???BETWEEN to_date(ny,'yyyymm')
? ?? ?? ?? ?? ?? ?? ?? ?? ?AND last_day(to_date(ny,'yyyymm'))
? ?? ?? ?? ?? ???)q
? ?? ?? ?) a? ?
? ? WHERE a.weekday NOT IN(0,6);? ?
??RETURN Result;??
END Get_WorkingDays;

方法三

CREATE OR REPLACE FUNCTION Get_WorkingDays(
??ny IN VARCHAR2
) RETURN INTEGER IS
/*-----------------------------------------------------------------------------------------
函数名称:Get_WorkingDays
中文名称:求某一年月中共有多少工作日
作者姓名: XINGPING
编写时间: 2004-05-23
输入参数:NY:所求包含工作日数的年月,格式为yyyymm,如200405
返 回 值:整型值,包含的工作日数目。
算法描述:使用Last_day函数计算出参数所给年月共包含多少天,根据这个值来构造一个循环。在这个循环中先求这个月的每一天与一个已知是星期天的日期(2001-12-30是星期天)的差,所得的差再对7求模。如果所求日期在2001-12-30以前,那么所得的差既是负数,求模后所得值范围为大于-6,小于0,如-1表示星期六,故先将求模的结果加7,再求7的模. 如过所得值不等于0和6(即不是星期六和星期天),则算一个工作日。? ?? ?
----------------------------------------------------------------------------------------*/
??Result INTEGER := 0;
??myts INTEGER;? ?? ?--所给年月的天数
??scts INTEGER;? ?? ?--某天距2001-12-30所差的天数
??rq? ?DATE;
??djt INTEGER := 1;? ?--
BEGIN
??myts := to_char(last_day(to_date(ny,'yyyymm')),'dd');??
??LOOP
? ? rq := TO_date(ny||substr(100+djt,2),'yyyymmdd');
? ? scts := rq - to_date('2001-12-30','yyyy-mm-dd');
? ? IF MOD(MOD(scts,7)+7,7) NOT IN(0,6) THEN
? ?? ?Result := Result + 1;
? ? END IF;
? ? djt := djt + 1;??
? ? EXIT WHEN djt>myts;
??END LOOP;??
??RETURN Result;??
END Get_WorkingDays;

java 计算工作日的。8小时制度

工作日的时间统计法。客制化的内容,使用者自行更改,代码内容不复杂,很简单,质量可能不入前辈的法眼,但是还是希望大神给意见,我好进步。为更多的开源做贡献,壮哉我大中华。...
  • yangying19911113
  • yangying19911113
  • 2014年04月21日 19:10
  • 1329

输入一个日期,****年**月**日,如何判断是否为工作日?

今天老师让写一个程序:输入日期,计算是否为工作日。秉承本人一向 能简单绝不 麻烦的原则,写下以下两个思路: 首先是第一种计算原理: 把你想要知道的日期号,加上该月份代号,再除以7,能整除的就是星期日;...
  • tsvico
  • tsvico
  • 2017年05月16日 12:59
  • 680

java计算工作日,排除周末以及法定假日

/** * Title: main * Description: TODO * @param args * return void 返回类型 * throws ...
  • u011789653
  • u011789653
  • 2014年11月24日 13:41
  • 13916

2017年最后两个工作日的年终总结

愿世界平安,永无战争。
  • Eric77
  • Eric77
  • 2017年12月29日 14:35
  • 300

java判断日期是否为工作日(排除节假日和调整周末上班)

项目需要判断当前日期是否为工作日,包括判断是否周末,是否节假日,是否周末调整上班。 判断是否周末,我们可以通过java方法就可以实现,但是判断是否节假日和,调整的周末上班,这个就需要我们自己去维护了。...
  • qq_23477421
  • qq_23477421
  • 2016年08月17日 13:27
  • 7696

python使用time、datetime返回工作日列表

最近在学习python,动手做了一个自动填写日报的小工具;由于请求中包含时间,格式如:2016-08-04;所以就了解了一下python的时间日期相关函数;这里做简单记录。 函数功能:获取当月所有工...
  • duyisen
  • duyisen
  • 2016年08月04日 14:52
  • 6545

工作日和非工作日数据查询

1、  查询时间段的报表添加搜索条件,使得日期查询支持区分工作日、非工作日,默认不区分。工作日指周一到周五,非工作日指周六日。 网上查找了好久资料,解决了,分享给大家。 查询数据 区分...
  • fengyanjiejob
  • fengyanjiejob
  • 2013年09月12日 10:16
  • 1147

计算两个日期之间的工作日天数

js计算两个日期之间的工作日天数
  • fb281906011
  • fb281906011
  • 2014年05月10日 10:50
  • 4683

jueryUI完成工作日设置

  • boss666666
  • boss666666
  • 2013年08月24日 22:03
  • 1266

Java计算加上指定工作日数(排除周六周日和一系列节日)

Java计算加上指定工作日数(排除周六周日和一系列节日)
  • jacke121
  • jacke121
  • 2017年02月18日 23:14
  • 2290
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:得出一个月有多少工作日
举报原因:
原因补充:

(最多只允许输入30个字)