当前位置: 首页 > 图文教程 > 数据库 > Oracle > 两种方法分析每月工作日计算程序
| SQL> SELECT TEXT FROM USER_SOURCE WHERE TYPE='PROCEDURE' AND NAME='GZR'; TEXT ---------------------------------------------------------------------------------------------------- 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 CREATE OR REPLACE FUNCTION Get_WorkingDays( ny IN VARCHAR2 ) RETURN INTEGER IS |